

# AN4809 Application note

## Migrating between STM32L0 Series and STM32L4 Series / STM32L4+ Series microcontrollers

#### Introduction

For the designers of STM32 microcontroller applications, being able to easily replace one microcontroller type by another between different product families is an important asset. Migrating an application to a different microcontroller is often needed when the product requirements grow putting extra demands on the memory size or increasing the number of I/Os. The cost reduction objectives may also be an argument to switch to smaller components and to shrink the PCB area.

This application note analyzes the required steps to migrate an existing design between STM32L0 Series and STM32L4 Series / STM32L4+ Series microcontrollers. Three aspects need to be considered for the migration: the hardware migration, the peripheral migration and the firmware migration.

This document lists the "full set" of features available for the STM32L0 Series and the STM32L4 Series / STM32L4+ Series (some products may have less features depending on their part number). It groups together the most important information and lists the key aspects that need to be addressed.

To fully benefit from this application note, the user should be familiar with the STM32 microcontrollers documentation available on <a href="https://www.st.com">www.st.com</a>, with a particular focus on:

- STM32L0 Series reference manuals:
  - RM0377 (STM32L0x1xx)
  - RM0376 (STM32L0x2xx)
  - RM0367 (STM32L0x3xx)
- STM32L0 Series datasheets.
- STM32L4 Series reference manuals:
  - RM0351 (STM32L4x6xx, STM32L4x5xx)
  - RM0394 (STM32L41xxx, STM32L42xxx, STM32L43xxx, STM32L44xxx, STM32L45xxx, STM32L46xxx)
  - RM0392 (STM32L471xx)
- STM32L4 Series datasheets
- STM32L4+ Series reference manual:
  - RM0432 (STM32L4Rxxx, STM32L4Sxxx)
- STM32L4+ Series datasheets

 September 2018
 AN4809 Rev 5
 1/75

Contents AN4809

## **Contents**

| 1           | _     | STM32L0 Series and STM32L4 Series / STM32L4+ Series overview7                        |  |  |  |  |  |  |
|-------------|-------|--------------------------------------------------------------------------------------|--|--|--|--|--|--|
|             | 1.1   | STM32L0 Series: ultra-low-power MCU                                                  |  |  |  |  |  |  |
|             | 1.2   | STM32L4 Series / STM32L4+ Series: ultra-low-power and performances 9                 |  |  |  |  |  |  |
| 2           | Hard  | ware migration                                                                       |  |  |  |  |  |  |
|             | 2.1   | Packages availability11                                                              |  |  |  |  |  |  |
|             | 2.2   | Pinout comparison                                                                    |  |  |  |  |  |  |
| 3           | Boot  | mode compatibility19                                                                 |  |  |  |  |  |  |
|             | 3.1   | Boot modes selection                                                                 |  |  |  |  |  |  |
|             | 3.2   | Embedded bootloader                                                                  |  |  |  |  |  |  |
| 4           | Low   | -power modes                                                                         |  |  |  |  |  |  |
|             | 4.1   | Low-power modes in STM32L0 Series                                                    |  |  |  |  |  |  |
|             | 4.2   | Low-power modes in STM32L4 Series / STM32L4+ Series                                  |  |  |  |  |  |  |
| 5           | Perip | oheral migration                                                                     |  |  |  |  |  |  |
|             | 5.1   | STM32Lx product cross-compatibility                                                  |  |  |  |  |  |  |
|             | 5.2   | Memory mapping 34                                                                    |  |  |  |  |  |  |
|             |       | 5.2.1 Global memory map                                                              |  |  |  |  |  |  |
|             |       | 5.2.2 Peripherals memory map                                                         |  |  |  |  |  |  |
|             | 5.3   | Direct memory access controller (DMA)                                                |  |  |  |  |  |  |
|             | 5.4   | Reset and clock control (RCC)                                                        |  |  |  |  |  |  |
|             | 5.5   | Power control (PWR)                                                                  |  |  |  |  |  |  |
|             | 5.6   | Flash memory                                                                         |  |  |  |  |  |  |
| 2<br>3<br>4 | 5.7   | Serial peripheral interface (SPI)/ IC to IC sound (I2S) serial audio interface (SAI) |  |  |  |  |  |  |
|             | 5.8   | USB 59                                                                               |  |  |  |  |  |  |
|             | 5.9   | Analog-to-digital converters (ADC) 60                                                |  |  |  |  |  |  |
|             | 5.10  | Digital-to-analog converter (DAC)                                                    |  |  |  |  |  |  |
|             | 5.11  | Comparator (COMP)                                                                    |  |  |  |  |  |  |
|             |       |                                                                                      |  |  |  |  |  |  |



| AN4809 | Contents |
|--------|----------|
|        |          |

| 6 | Firm | ware migration |
|---|------|----------------|
|   | 6.1  | HAL FLASH 64   |
|   | 6.2  | HAL_PWR 67     |
|   | 6.3  | HAL RCC 70     |
| 7 | Revi | sion history   |



List of tables AN4809

## List of tables

| Table 1.  | STM32L0 Series product category overview                                    | 7    |
|-----------|-----------------------------------------------------------------------------|------|
| Table 2.  | STM32L0 Series feature levels                                               |      |
| Table 3.  | STM32L0 memory amount availability and feature levels                       |      |
| Table 4.  | STM32L4 Series / STM32L4+ Series feature levels                             |      |
| Table 5.  | STM32L4 Series / STM32L4+ Series memory availability                        |      |
| Table 6.  | Packages available on STM32L4 Series and STM32L4+ Series                    | . 11 |
| Table 7.  | Packages available on STM32L0 Series                                        |      |
| Table 8.  | Pinout differences on LQFP32 package                                        |      |
| Table 9.  | Pinout differences on UFQFPN32 package                                      |      |
| Table 10. | Pinout differences on LQFP48 package                                        |      |
| Table 11. | Pinout differences on LQFP64 package                                        |      |
| Table 12. | Pinout differences on LQFP100 package                                       |      |
| Table 13. | Pinout differences on BGA64 package                                         |      |
| Table 14. | Pinout differences on UFBGA100 package                                      |      |
| Table 15. | Boot mode selection for STM32L0 Cat. 2, 3, 5 and STM32L47xxx/L48xxx devices |      |
| Table 16. | Boot mode selection for STM32L0 Cat. 1 access line                          |      |
| Table 17. | Boot modes for STM32L41xxx/L42xxx, STM32L43xxx/L44xxx, STM32L45xxx/L46xxx,  |      |
|           | STM32L49xxx/L4Axxx and STM32L4Rxxx/4Sxxx devices                            | . 21 |
| Table 18. | Boot serial interfaces                                                      | . 22 |
| Table 19. | STM32L0 Series low-power modes summary                                      |      |
| Table 20. | STM32L4 Series / STM32L4+ Series low-power modes summary                    |      |
| Table 21. | Peripherals comparison between STM32L0 Series and                           |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 28 |
| Table 22. | Peripherals memory map                                                      | . 36 |
| Table 23. | DMA request differences migrating STM32L0 Series to                         |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 39 |
| Table 24. | RCC comparison between STM32L0 Series and                                   |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 45 |
| Table 25. | Performance versus V <sub>CORE</sub> ranges                                 |      |
| Table 26. | PWR comparison between STM32L0 Series and                                   |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 51 |
| Table 27. | FLASH differences between STM32L0 Series and                                |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 54 |
| Table 28. | SPI differences between STM32L0 Series and                                  |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 57 |
| Table 29. | Audio interface support in STM32L0 Series and                               |      |
|           | STM32L4 Series / STM32L4+ Series                                            |      |
| Table 30. | USB peripheral comparison                                                   | . 59 |
| Table 31. | ADC differences between STM32L0 Series and                                  |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 60 |
| Table 32. | DAC differences between STM32L0 Series and                                  |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 62 |
| Table 33. | COMP differences between STM32L0 Series and                                 |      |
|           | STM32L4 Series / STM32L4+ Series                                            | . 63 |
| Table 34. | Option byte structure comparison                                            | . 65 |
| Table 35. | FLASH generic API                                                           |      |
| Table 36. | FLASH extended API                                                          |      |
| Table 37. | HAL PWR                                                                     | . 67 |



| AN4809    |                                           | List of tables |
|-----------|-------------------------------------------|----------------|
| Table 38. | HAL_PWREx                                 | 68             |
|           | PLL configuration                         |                |
|           | RCC extended peripheral control functions |                |
| Table 41. | Document revision history                 |                |



List of figures AN4809

## List of figures

| Figure 1. | STM32L0 Series memory map                   | 34 |
|-----------|---------------------------------------------|----|
| Figure 2. | STM32L4 Series / STM32L4+ Series memory map | 35 |
| Figure 3. | STM32L0 Series clock tree                   | 42 |
| Figure 4. | STM32L49xxx/L4Axxx clock tree               | 43 |
| Figure 5. | STM32L4Rxx/4Sxxx clock tree                 | 44 |
| Figure 6. | STM32L0 Series power supply                 | 48 |
| Figure 7. | STM32L4 Series power supply                 | 49 |
| Fiaure 8. | STM32L4+ Series power supply overview       | 50 |



## 1 STM32L0 Series and STM32L4 Series / STM32L4+ Series overview

STM32L0 Series and STM32L4 Series / STM32L4+ Series have in common the achievement of an outstanding low-power consumption level. They are all genuine ultra-low-power MCUs with record breaking.

STM32L0 Series target the very low-power applications while STM32L4 Series / STM32L4+ Series bring additional processing performances and new peripherals.

The detailed list of available features and packages for each product is available in the respective product's datasheet. As reminded in *Table 1* the STM32L0 Series products have been organized in categories to ease the referencing.

Table 1. STM32L0 Series product category overview

| Type <sup>(1)</sup> | Part number              |
|---------------------|--------------------------|
| Category 1          | STM32L01xxx, STM32L02xxx |
| Category 2          | STM32L03xxx, STM32L04xxx |
| Category 3          | STM32L05xxx, STM32L06xxx |
| Category 5          | STM32L07xxx, STM32L08xxx |

<sup>1.</sup> Category X devices are referred as "Cat. X" devices within this document.

This document applies to Arm<sup>®(a)</sup>-based devices.

arm

a. Arm is a registered trademark of Arm Limited (or its subsidiaries) in the US and/or elsewhere.



AN4809 Rev 5 7/75

#### 1.1 STM32L0 Series: ultra-low-power MCU

The exclusive combination of an ARM<sup>®</sup> Cortex<sup>®</sup>-M0+ core (max speed 32 MHz) and STM32 ultra-low-power features, makes STM32L0 Series the best fit for applications operating on battery or supplied by energy harvesting and the world's lowest power consumption MCU at 125°C.

STM32L0 Series offer a dynamic voltage scaling, an ultra-low-power clock oscillator, LCD interface, comparators, DAC and hardware encryption. Autonomous peripherals (including USART, I2C, touch sense controller) reduce the load of the ARM® Cortex®-M0+ core leading to fewer CPU wakeups and contribute to decrease the processing time and the power consumption.

Other value-added features such as the 16-bit ADC (HW oversampling), the crystal-less USB, short wakeup time and communication peripherals capable of operating in Ultra-low-power mode, make up for an unrivaled tradeoff between the feature integration, the performance and ultra-low-energy consumption.

The STM32L0 Series devices are available with up to 192 Kbytes of Flash memory, 20 Kbytes of RAM and up to 6 Kbytes of embedded EEPROM (no emulation needed) in 14- to 100-pin packages. Three feature levels and four categories cover a wide range of customer needs. *Table 2* and *Table 3* summarize the feature levels and memory availability of the STM32L0 Series products.

| Feature level | Additional features                                                                                                                                   |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | - Access Line                                                                                                                                         |
| 2             | <ul><li>Crystal-less USB 2.0 FS (BCD, LPM compliant)</li><li>16 capacitive touch keys</li><li>True random number generator (TRNG)</li></ul>           |
| 3             | <ul> <li>Crystal-less USB 2.0 FS</li> <li>16 capacitive touch keys</li> <li>True random number generator (TRNG)</li> <li>LCD driver (8x48)</li> </ul> |

Table 2. STM32L0 Series feature levels

Table 3. STM32L0 memory amount availability and feature levels

| Category | Part number | Flash size<br>(Kbytes) | EEPROM size<br>(Kbytes) <sup>(1)</sup> | Ram size<br>(Kbytes) | Feature level |
|----------|-------------|------------------------|----------------------------------------|----------------------|---------------|
| Cat 1    | STM32L01xxx | 8/16                   | 0.5                                    | 2                    | 1             |
| Cat. 1   | STM32L02xxx | 0/10                   | 0,5                                    | 2                    | 1 + AES       |
| Cat. 2   | STM32L03xxx | 16/32                  | 1                                      | 8                    | 1,2           |
| Cat. 2   | STM32L04xxx | 10/32                  | I                                      | 0                    | 1             |
| Cat. 3   | STM32L05xxx | 32/64                  | 2                                      | 8                    | 1,2,3         |
| Cat. 5   | STM32L06xxx | 32/04                  | 2                                      | 0                    | 2,3 + AES     |
| Cat. 5   | STM32L07xxx | 64/128/192             | 3/6                                    | 20                   | 1,2,3         |
|          | STM32L08xxx | 04/120/192             | 3/6                                    | 20                   | 1,2,3 + AES   |

<sup>1.</sup> Not available for all part numbers.



## 1.2 STM32L4 Series / STM32L4+ Series: ultra-low-power and performances

The STM32L4 Series / STM32L4+ Series devices extend the ultra-low-power portfolio and performance with the ARM $^{\mathbb{R}}$  Cortex $^{\mathbb{R}}$ -M4 core with DSP, floating-point unit (FPU) and START Accelerator $^{\mathsf{TM}}$  at up to 120 MHz.

The STM32L4 Series / STM32L4+ Series devices have scored 153 (world record) in the standardized EEMBC™ ULPBench® tests that compare the efficiency of ultra-low-power microcontrollers.

The STM32L4 Series / STM32L4+ Series devices offer from 256 Kbytes to 2 Mbytes of Flash memory and from 32- to 169-pin packages. Their memory range can easily be extended using SDIO, Quad-SPI, Octo-SPI and FSMC interfaces.

*Table 4* and *Table 5* summarize the feature levels and memory availability of STM32L4 Series / STM32L4+ Series.

 Feature level
 Additional features

 1
 Access line

 2
 1 + USB specification version 2.0 full-speed

 3
 2 + liquid crystal display controller

 4
 1 + USB FS OTG

 5
 4 + LCD

 7
 5 + LTDC

 9
 7 + DSI

Table 4. STM32L4 Series / STM32L4+ Series feature levels



AN4809 Rev 5 9/75

Table 5. STM32L4 Series / STM32L4+ Series memory availability

| Part number | Flash size |                             |             | Feature   |            |          |
|-------------|------------|-----------------------------|-------------|-----------|------------|----------|
| Part number | Size       | Bank                        | SRAM1 SRAM2 |           | SRAM3      | level    |
| STM32L4S9xx |            |                             |             |           |            | 9+crypto |
| STM32L4R9xx |            |                             |             |           |            | 9        |
| STM32L4S7xx | O Mbutaa   | Dual                        | 100 Khyton  | C4 Khytaa | 204 Khytaa | 7+crypto |
| STM32L4R7xx | 2 Mbytes   | Dual                        | 192 Kbytes  | 64 Kbytes | 384 Kbytes | 7        |
| STM32L4S5xx |            |                             |             |           |            | 5+crypto |
| STM32L4R5xx |            |                             |             |           |            | 5        |
| STM32L496xx |            |                             | 256 Khytoo  | 64 Khytos |            | 6        |
| STM32L4A6xx |            |                             | 256 Kbytes  | 64 Kbytes |            | 6+crypto |
| STM32L471xx | 1 Mbyte    | Dual                        |             | 32 Kbytes |            | 1        |
| STM32L475xx |            | Dual                        | 00 1/1-1    |           |            | 5        |
| STM32L476xx |            |                             | 96 Kbytes   |           |            | 6        |
| STM32L486xx |            |                             |             |           |            | 6+crypto |
| STM32L451xx |            |                             |             |           |            | 1        |
| STM32L452xx | 512 Kbytes | Single                      | 128 Kbytes  | 32 Kbytes | NIA        | 2        |
| STM32L462xx |            |                             |             |           | NA         | 2+crypto |
| STM32L431xx |            |                             |             |           |            | 1        |
| STM32L432xx |            |                             |             |           |            | 2        |
| STM32L442xx | 256 Kbytes | Single                      | 48 Kbytes   | 16 Kbytes |            | 2+crypto |
| STM32L433xx |            |                             |             |           |            | 3        |
| STM32L443xx |            |                             |             |           |            | 3+crypto |
| STM32L412xx | 120 Khytes | Single                      | 22 Khytes   | 9 Khytoc  |            | 2        |
| STM32L422xx | 128 Kbytes | Kbytes   Single   32 Kbytes | 32 Kbytes   | 8 Kbytes  |            | 2+crypto |



AN4809 Hardware migration

## 2 Hardware migration

#### 2.1 Packages availability

STM32L0 Series and STM32L4 Series / STM32L4+ Series have a wide selection of packages. The STM32L0 Series devices offer starts with small 14-pin packages and goes up to 100-pin packaged. The STM32L4 Series / STM32L4+ Series devices offer spreads from 32- to 169-pin packages.

The available packages in STM32L4 Series / STM32L4+ Series are listed in *Table 6*.

Table 6. Packages available on STM32L4 Series and STM32L4+ Series

|                        | STM32L4+<br>Series | STM32L4 Series            |                           |                           |                           |                           | Size               | 1                                                                                                                           |
|------------------------|--------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Package <sup>(1)</sup> |                    | STM32L<br>49xxx/<br>4Axxx | STM32L<br>47xxx/<br>48xxx | STM32L<br>45xxx/<br>46xxx | STM32L<br>43xxx/<br>44xxx | STM32L<br>41xxx/<br>42xxx | (mm x<br>mm)       | Applicable part numbers                                                                                                     |
| UFQFPN32               | -                  | -                         | -                         | -                         | ×                         | x                         | (5 x 5)            | STM32L412xx,<br>STM32L422xx,<br>STM32L431xx,<br>STM32L432xx,<br>STM32L442xx                                                 |
| LQFP32                 | -                  | -                         | -                         | -                         | -                         | Х                         | (5 x 5)            | STM32L412xx,<br>STM32L422xx                                                                                                 |
| LQFP48                 | -                  | -                         | -                         | -                         | x                         | ×                         | (7 x 7)            | STM32L412xx,<br>STM32L422xx,<br>STM32L431xx,<br>STM32L433xx,<br>STM32L443xx                                                 |
| UFQFPN48               | -                  | -                         | -                         | X                         | X                         | X                         | (7 x 7)            | STM32L412xx,<br>STM32L422xx,<br>STM32L431xx,<br>STM32L433xx,<br>STM32L443xx,<br>STM32L451xx,<br>STM32L452xx,<br>STM32L462xx |
| WLCSP36                | -                  | -                         | -                         | -                         | -                         | Х                         | (2.85 x<br>3.07)   | STM32L412xx,<br>STM32L422xx                                                                                                 |
| WLCSP49                | -                  | -                         | -                         | -                         | х                         | -                         | (3.141 x<br>3.127) | STM32L431xx,<br>STM32L433xx,<br>STM32L443xx                                                                                 |
| WLCSP64                | -                  | -                         | -                         | -                         | Х                         | -                         | (3.141 x<br>3.127) | STM32L431xx,<br>STM32L433xx,<br>STM32L443xx                                                                                 |



AN4809 Rev 5 11/75

Hardware migration AN4809

Table 6. Packages available on STM32L4 Series and STM32L4+ Series (continued)

|                        | STM32L4+<br>Series | STM32L4 Series            |                           |                           |                           |                           | Size                 |                                                                                                                                                                                                                             |
|------------------------|--------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Package <sup>(1)</sup> |                    | STM32L<br>49xxx/<br>4Axxx | STM32L<br>47xxx/<br>48xxx | STM32L<br>45xxx/<br>46xxx | STM32L<br>43xxx/<br>44xxx | STM32L<br>41xxx/<br>42xxx | (mm x<br>mm)         | Applicable part numbers                                                                                                                                                                                                     |
| LQFP64                 | -                  | X                         | X                         | X                         | X                         | X                         | (10 x 10)            | STM32L412xx,<br>STM32L422xx,<br>STM32L431xx,<br>STM32L433xx,<br>STM32L443xx,<br>STM32L451xx,<br>STM32L452xx,<br>STM32L462xx,<br>STM32L476xx,<br>STM32L476xx,<br>STM32L476xx,<br>STM32L486xx,<br>STM32L496xx,<br>STM32L4A6xx |
| UFBGA64                | -                  | -                         | -                         | X                         | X                         | X                         | (5 x 5)              | STM32L412xx,<br>STM32L422xx,<br>STM32L431xx,<br>STM32L433xx,<br>STM32L443xx,<br>STM32L451xx,<br>STM32L452xx,<br>STM32L462xx                                                                                                 |
| WLCSP64                | -                  | -                         | -                         | х                         | -                         | -                         | (3.357 x<br>3.657)   | STM32L451xx,<br>STM32L452xx,<br>STM32L462xx                                                                                                                                                                                 |
| WLCSP72                | -                  | -                         | Х                         | -                         | -                         | -                         | (4.4084 x<br>3.7594) | STM32L471xx,<br>STM32L475xx,<br>STM32L476xx,<br>STM32L486xx                                                                                                                                                                 |
| WLCSP81                | -                  | -                         | Х                         | -                         | -                         | -                         | (4.4084 x<br>3.7594) | STM32L476xx                                                                                                                                                                                                                 |
| WLCSP100               | -                  | Х                         | -                         | -                         | -                         | -                         | (4.618 x<br>4.142)   | STM32L496xx,<br>STM32L4A6xx                                                                                                                                                                                                 |

AN4809 Hardware migration

Table 6. Packages available on STM32L4 Series and STM32L4+ Series (continued)

|                        |                    | STM32L4 Series            |                           |                           |                           |                           | Size         |                                                                                                                                                                                                                                                                              |
|------------------------|--------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Package <sup>(1)</sup> | STM32L4+<br>Series | STM32L<br>49xxx/<br>4Axxx | STM32L<br>47xxx/<br>48xxx | STM32L<br>45xxx/<br>46xxx | STM32L<br>43xxx/<br>44xxx | STM32L<br>41xxx/<br>42xxx | (mm x<br>mm) | Applicable part numbers                                                                                                                                                                                                                                                      |
| LQFP100                | X                  | X                         | X                         | X                         | X                         | -                         | (14 x 14)    | STM32L431xx,<br>STM32L433xx,<br>STM32L443xx,<br>STM32L451xx,<br>STM32L452xx,<br>STM32L462xx,<br>STM32L475xx,<br>STM32L476xx,<br>STM32L476xx,<br>STM32L486xx,<br>STM32L486xx,<br>STM32L485xx,<br>STM32L4R5xx,<br>STM32L4R9xx,<br>STM32L4R9xx,<br>STM32L4S5xx,<br>STM32L4S5xx, |
| UFBGA100               | -                  | -                         | х                         | х                         | Х                         | -                         | (7 x 7)      | STM32L431xx,<br>STM32L433xx,<br>STM32L443xx                                                                                                                                                                                                                                  |
| UFBGA132               | X                  | X                         | X                         | -                         | -                         | -                         | (7 x 7)      | STM32L471xx,<br>STM32L475xx,<br>STM32L476xx,<br>STM32L486xx,<br>STM32L496xx,<br>STM32L4A6xx,<br>STM32L4R5xx,<br>STM32L4S5xx                                                                                                                                                  |
| UFBGA144               | Х                  | -                         | -                         | -                         | -                         | -                         | (10 x 10)    | STM32L4R9xx,<br>STM32L4S9xx                                                                                                                                                                                                                                                  |
| LQFP144                | X                  | X                         | X                         | -                         | -                         | -                         | (20 x 20)    | STM32L471xx,<br>STM32L475xx,<br>STM32L476xx,<br>STM32L486xx,<br>STM32L496xx,<br>STM32L4A6xx,<br>STM32L4R5xx,<br>STM32L4R9xx,<br>STM32L4S5xx,<br>STM32L4S9xx                                                                                                                  |

Hardware migration AN4809

Table 6. Packages available on STM32L4 Series and STM32L4+ Series (continued)

|                        |                    |                           | ST                        | M32L4 Ser                 | ies                       |                           | Size             |                                                                                             |
|------------------------|--------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|------------------|---------------------------------------------------------------------------------------------|
| Package <sup>(1)</sup> | STM32L4+<br>Series | STM32L<br>49xxx/<br>4Axxx | STM32L<br>47xxx/<br>48xxx | STM32L<br>45xxx/<br>46xxx | STM32L<br>43xxx/<br>44xxx | STM32L<br>41xxx/<br>42xxx | (mm x<br>mm)     | Applicable part numbers                                                                     |
| WLCSP144               | ×                  | -                         | -                         | -                         | -                         | -                         | (5.24 x<br>5.24) | STM32L4R5xx,<br>STM32L4R7xx,<br>STM32L4R9xx,<br>STM32L4S5xx,<br>STM32L4S7xx,<br>STM32L4S9xx |
| UFBGA169               | Х                  | Х                         | -                         | -                         | -                         | -                         | (7 x 7)          | STM32L496xx,<br>STM32L4A6xx,<br>STM32L4R5xx,<br>STM32L4R9xx,<br>STM32L4S5xx,<br>STM32L4S9xx |

<sup>1.</sup> X = supported.

AN4809 Hardware migration

The available packages in STM32L0 Series are listed in *Table 7*.

Table 7. Packages available on STM32L0 Series

| Package <sup>(1)</sup> |        | STM32L0 Series |        |        |  |  |  |
|------------------------|--------|----------------|--------|--------|--|--|--|
| Package.               | Cat. 1 | Cat. 2         | Cat. 3 | Cat. 5 |  |  |  |
| TSSOP14                | Х      | -              | -      | -      |  |  |  |
| TSSOP20                | Х      | Х              | -      | -      |  |  |  |
| UFQFPN20               | Х      | -              | -      | -      |  |  |  |
| UFQFPN28               | Х      | Х              | -      | -      |  |  |  |
| UFQFPN32               | Х      | Х              | Х      | Х      |  |  |  |
| UFQFPN48               | -      | -              | -      | -      |  |  |  |
| WLCSP25                | Х      | Х              | -      | -      |  |  |  |
| WLCSP36                | -      | -              | Х      | -      |  |  |  |
| WLCSP49                | -      | -              | -      | Х      |  |  |  |
| WLCSP64                | -      | -              | -      | -      |  |  |  |
| WLCSP72                | -      | -              | -      | -      |  |  |  |
| WLCSP81                | -      | -              | -      | -      |  |  |  |
| LQFP32                 | Х      | Х              | Х      | Х      |  |  |  |
| LQFP48                 | -      | Х              | Х      | Х      |  |  |  |
| LQFP64                 | -      | -              | Х      | Х      |  |  |  |
| LQFP100                | -      | -              | -      | Х      |  |  |  |
| LQFP144                | -      | -              | -      | -      |  |  |  |
| TFBGA64                | -      | -              | Х      | Х      |  |  |  |
| UFBGA64                | -      | -              | -      | Х      |  |  |  |
| UFBGA100               | -      | -              | -      | Х      |  |  |  |
| UFBGA132               | -      | -              | -      | -      |  |  |  |

<sup>1.</sup> X = supported.

For a detailed availability and a package selection, refer to the STM32L0 Series and STM32L4 Series / STM32L4+ Series web pages and available datasheets.

#### **SMPS** packages

Some STM32L4 Series / STM32L4+ Series devices offer a package option allowing the connection of an external SMPS. This is done through two VDD12 pins that are replacing two existing pins in the package baseline.

The compatibility is kept between the STM32L4 Series / STM32L4+ Series derivatives regarding those two pins (the pins replaced are different across the package types but are the same for all the derivatives on similar packages). Refer to the product datasheet for details.



AN4809 Rev 5 15/75

Hardware migration AN4809

#### 2.2 **Pinout comparison**

STM32L0 Series and STM32L4 Series / STM32L4+ Series share a high level of pin compatibility. Most of the peripherals share the same pins in the two families hence the transition between the two series is simple as only few pins are impacted.

The next tables (from Table 8 to Table 12) compare the pinout for 32-, 48-, 64- and 100-pin packages.

|   | Table 8. Pinout differences on LQFP32 package <sup>(1)</sup> |      |         |  |  |
|---|--------------------------------------------------------------|------|---------|--|--|
|   | Pin r                                                        | name |         |  |  |
| ) |                                                              |      | Comment |  |  |

|        | Pin r          | name                                |                                                          |
|--------|----------------|-------------------------------------|----------------------------------------------------------|
| Pin Nb | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comment                                                  |
| 5      | VDDA           | VIJIJA/VREE+                        | No pin is dedicated to VREF+ in this package, VREF+=VDDA |

The pinout of STM32L0 Cat. 5 UFQFPN32 devices are not compatible with other STM32L0 devices. Refer to the dedicated datasheet.

Table 9. Pinout differences on UFQFPN32 package<sup>(1)</sup>

|        | Pin r          | name                                |                                                          |  |
|--------|----------------|-------------------------------------|----------------------------------------------------------|--|
| Pin Nb | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comment                                                  |  |
| 5      | VDDA           | VDDA/VREF+                          | No pin is dedicated to VREF+ in this package, VREF+=VDDA |  |
| 16     | PB2            | VSS                                 | PB2 and PB8 IOs do not exist in                          |  |
| 32     | PB8            | VSS                                 | STM32L4 Series / STM32L4+ Series on this package         |  |

The pinout of STM32L0 Cat. 5 UFQFPN32 devices are not compatible with other STM32L0 devices. Refer to the dedicated datasheet.

Table 10. Pinout differences on LQFP48 package

|        | Pin r          | name                                |                                                                                                              |  |
|--------|----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------|--|
| Pin Nb | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comment                                                                                                      |  |
| 1      | VLCD           | VBAT                                | VLCD is an alternate function of PB2 pins on STM32L4 Series / STM32L4+ Series VBAT does not exist in STM32L0 |  |
| 8      | VSSA           | VSSA/VREF-                          | PB2 and PB8 IOs do not exist in STM32L4 on this package                                                      |  |
| 9      | VDDA           | VDDA/VREF+                          |                                                                                                              |  |



AN4809 Hardware migration

Table 11. Pinout differences on LQFP64 package

|        | Pin r          | name                                |                                                                                                                       |
|--------|----------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| Pin Nb | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comment                                                                                                               |
| 1      | VLCD           | VBAT                                | VLCD is an alternate function of PC3<br>pins on STM32L4 Series /<br>STM32L4+ Series<br>VBAT does not exist in STM32L0 |
| 12     | VSSA           | VSSA/VREF-                          | No pins are dedicated to VREF- and                                                                                    |
| 13     | VDDA           | VDDA/VREF+                          | VREF+ in this package: VREF-=VSSA VREF+=VDDA                                                                          |

Table 12. Pinout differences on LQFP100 package

|        | Pin r                                              | name   |                                                                                                                     |
|--------|----------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------|
| Pin Nb | Nb STM32L0 Series STM32L4 Series / STM32L4+ Series |        | Comment                                                                                                             |
| 6      | VLCD                                               | VBAT   | VLCD is an alternate function of PC3 pins on STM32L4 Series / STM32L4+ Series VBAT does not exist in STM32L0 Series |
| 10     | PH9                                                | VSS    | PH9 and PH10 IOs do not exist in                                                                                    |
| 11     | PH10                                               | VDD    | STM32L4 Series / STM32L4+ Series                                                                                    |
| 73     | VDD                                                | VDDUSB | -                                                                                                                   |
| 75     | VDD_USB                                            | VDD    | -                                                                                                                   |

Table 13. Pinout differences on BGA64 package

|        | Pin r          | name                                | Comment                                                 |  |
|--------|----------------|-------------------------------------|---------------------------------------------------------|--|
| Pin Nb | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series |                                                         |  |
| B2     | VDD            | VBAT                                | -                                                       |  |
| B4     | воото          | BOOT0/PH3                           | -                                                       |  |
| E5     | VDD            | VDDUSB                              | VDDUSB is available only in<br>STM32L433/L443/L452/L462 |  |
| E6     | VDDIO2         | VDD                                 | -                                                       |  |
| F1     | VSSA           | VSSA/VREF-                          | -                                                       |  |
| G1     | VREF+          | PC3                                 | -                                                       |  |
| H1     | VDDA           | VDDA/VREF+                          | -                                                       |  |



AN4809 Rev 5 17/75

Hardware migration AN4809

Table 14. Pinout differences on UFBGA100 package

|        | Pin r          | name                                |                                                      |
|--------|----------------|-------------------------------------|------------------------------------------------------|
| Pin Nb | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comment                                              |
| A4     | воото          | BOOT0/PH3                           | -                                                    |
| C11    | VDD            | VDDUSB                              | VDDUSB is available only<br>STM32L443/L433/L452/L462 |
| E2     | VDD            | VBAT                                | -                                                    |
| F2     | PH9            | VSS                                 | -                                                    |
| G2     | PH10           | VDD                                 | -                                                    |
| G11    | VDDIO2         | VDD                                 | -                                                    |

Note:

STM32L4R9xx/4S9xx are not compatible with STM32L4 Series, for more details please refer to application note Migration between STM32L476xx/486xx and STM32L4Rxxx/4Sxxx microcontrollers (AN5017).

### 3 Boot mode compatibility

#### 3.1 Boot modes selection

The boot modes selection (main Flash memory, system Flash memory or embedded SRAM) are very close between both series of products. The selection is done through the BOOT0 pin and other option bits.

In small packages, the BOOT0 pin is shared with a GPIO. However, the BOOT0 logic can be controlled by an option bit. This option is available for the STM32L0 Cat. 1 and the STM32L47xxx/L48xxx devices.

#### STM32L0 Cat. 2, 3, 5 and STM32L47xxx/L48xxx devices

Table 15 shows the boot mode selected function of BOOT0 pin and BOOT1 option bit.

Table 15. Boot mode selection for STM32L0 Cat. 2, 3, 5 and STM32L47xxx/L48xxx devices

| BOOT1 bit <sup>(1)</sup> | BOOT0 pin | Boot              |
|--------------------------|-----------|-------------------|
| X                        | 0         | Main Flash memory |
| 0                        | 1         | System memory     |
| 1                        | 1         | Embedded SRAM     |

<sup>1.</sup> X =equivalent to 0 or 1.



AN4809 Rev 5 19/75

## STM32L0 Cat. 1 and STM32L41xxx/42xxx, STM32L43xxx/L44xxx, STM32L45xxx/L46xxx, STM32L49xxx/L4Axxx and STM32L4Rxxx/4Sxxx devices

Table 16 shows the boot mode selection for the STM32L0 Cat. 1 devices.

Table 16. Boot mode selection for STM32L0 Cat. 1 access line<sup>(1)</sup>

| nBOOT1<br>bit <sup>(2)</sup> | BOOT0<br>pin | nBOOT_SEL<br>bit | nBOOT0 pin | Main Flash<br>memory empty <sup>(3)</sup> | Boot memory space    |                  |                      |
|------------------------------|--------------|------------------|------------|-------------------------------------------|----------------------|------------------|----------------------|
| X                            | 0            |                  | ×          |                                           | 0                    |                  | Main Flash<br>memory |
| ^                            | U            | 0 (BOOT0         | 0 (BOOT0   | 0 (BOOT0                                  |                      | 1                | System<br>memory     |
| 1                            | 1            | pin)             | pin)       | Х                                         | Х                    | System<br>memory |                      |
| 0                            | 1            |                  | ×          | X                                         | Embedded<br>SRAM     |                  |                      |
| X                            | Х            |                  | 1          | Х                                         | Main Flash<br>memory |                  |                      |
| 1                            | Х            | 1 (BOOT0 bit)    | 0          | Х                                         | System memory        |                  |                      |
| 0                            | Х            |                  | 0          | Х                                         | Embedded<br>SRAM     |                  |                      |

- 1. The cells highlighted in gray concern only the STM32L011xx and the STM32L021xx devices.
- 2. X =equivalent to 0 or 1.
- 3. A Flash empty check mechanism is implemented to force the boot from system Flash, if the first Flash memory location is not programmed (0xFFFF FFFF) and if the boot selection is configured to boot from the main Flash memory.

The STM32L0 Cat. 1 devices share the BOOT0 pin with a GPIO pin. The selection of BOOT0 as a pin or an option bit is done by the BOOT\_SEL option bit. If the boot target is the main Flash memory and the Flash memory is empty, the boot is automatically redirected on the system memory.

In the STM32L41xxx/42xxx, STM32L43xxx/L44xxx, STM32L45xxx/L46xxx, STM32L49xxx/L4Axxx and STM32L4Rxxx/4Sxxx devices, the boot mode is selected with the nBOOT1 option bit and the pin BOOT0 or the nBOOT0 option bit depending on the value of the nSWBOOT0 option bit in the FLASH\_OPTR register as shown in *Table 17*.

20/75 AN4809 Rev 5

Table 17. Boot modes for STM32L41xxx/L42xxx, STM32L43xxx/L44xxx, STM32L45xxx/L46xxx,

#### STM32L49xxx/L4Axxx and STM32L4Rxxx/4Sxxx devices

| nBOOT1<br>FLASH_OPTR<br>[23] | nBOOT0<br>FLASH_OPTR<br>[27] | BOOT0<br>pin PH3 | nSWBOOT0<br>FLASH_OPTR<br>[26] | Main Flash<br>empty <sup>(1)</sup> | Boot Memory<br>Space Alias                          |
|------------------------------|------------------------------|------------------|--------------------------------|------------------------------------|-----------------------------------------------------|
| Х                            | х                            | 0                | 1                              | 0                                  | Main Flash<br>memory is<br>selected as<br>boot area |
| Х                            | Х                            | 0                | 1                              | 1                                  | System<br>memory is<br>selected as<br>boot area     |
| Х                            | 1                            | Х                | 0                              | Х                                  | Main Flash<br>memory is<br>selected as<br>boot area |
| 0                            | Х                            | 1                | 1                              | Х                                  | Embedded<br>SRAM1 is<br>selected as<br>boot area    |
| 0                            | 0                            | Х                | 0                              | Х                                  | Embedded<br>SRAM1 is<br>selected as<br>boot area    |
| 1                            | Х                            | 1                | 1                              | Х                                  | System<br>memory is<br>selected as<br>boot area     |
| 1                            | 0                            | Х                | 0                              | Х                                  | System<br>memory is<br>selected as<br>boot area     |

Only for the STM32L45xxx/L46xxx, STM32L43xxx/L44xxx and STM32L41xxx/42xxx devices: a Flash empty check mechanism is implemented to force the boot from system Flash if the first Flash memory location is not programmed (0xFFFF FFFF) and if the boot selection is configured to boot from the main Flash memory.



AN4809 Rev 5 21/75

#### 3.2 Embedded bootloader

The embedded bootloader is located in the system memory, programmed by ST during the production. It is used to reprogram the Flash memory using one of the following serial interfaces.

STM32L4 Series / STM32L4+ Series offer a wider range of interfaces compared to STM32L0 Series. *Table 18* lists all the interface possibilities.

STM32L 082xx STM32L STM32L STM32L STM32L STM32L 02xxx 04xxx 06xxx 081xx 072xx STM32L4 **Interfaces** STM32L STM32L STM32L STM32L STM32L Series 01xxx 03xxx 05xxx 071xx 083xx STM32L 073xx DFU Χ USART1 Χ Χ Χ Χ USART2 Χ Χ Χ Χ Χ Χ **USART3** ---Χ I2C1 Χ Χ 12C2 Χ Χ \_ 12C3 Χ  $X^{(2)}$ I2C4 \_ \_ \_ \_ \_ SPI1 Χ Χ Χ Χ Χ SPI2 Χ Χ Χ \_ \_ SPI3  $X^{(3)}$ CAN1  $X^{(4)}$ CAN2

Table 18. Boot serial interfaces

For details concerning the bootloader serial interface corresponding I/O, refer to the device datasheets. For other details concerning the bootloader on all STM32 devices, refer to application note *STM32 microcontroller system memory boot mode* (AN2606).

22/75 AN4809 Rev 5

<sup>1. &</sup>quot;X": interface available.

<sup>2.</sup> Only for STM32L45xxx/L46xxx devices.

<sup>3.</sup> Not available on STM32L41xxx/L42xxx devices.

<sup>4.</sup> Only for STM32L49xxx/L4Axxx devices.

AN4809 Low-power modes

### 4 Low-power modes

By default, the microcontroller is in Run mode after a system or a power reset. Several low-power modes are available to save power when the CPU does not need to be kept running, for example when waiting for an external event. It is up to the user to select the mode that gives the best compromise between a low-power consumption, a short startup time and available wakeup sources.

STM32L0 Series and STM32L4 Series / STM32L4+ Series share the same main low-power modes (Low-power run, Stop, Sleep, Low-power sleep and Standby) with voltage ranges specifics to each series. STM32L4 Series / STM32L4+ Series offer in addition three stop modes (Stop 0 and Stop 1 with USB capabilities and Stop 2) and a new shutdown mode.

Details on the low-power modes configuration in each series can be found in the device reference manual. The consumption figures are given in the device datasheets.

#### 4.1 Low-power modes in STM32L0 Series

#### Low-power modes

The STM32L0 Series devices have the five following low-power modes:

- Low-power run mode: regulator in low-power mode, limited clock frequency, limited number of peripherals running.
- Sleep mode: CPU stopped, peripherals kept running.
- Low-power sleep mode: CPU stopped, limited clock frequency, limited number of peripherals running, regulator in low-power mode, Flash memory stopped
- Stop mode: SRAM and all registers content are retained. All clocks in the VCORE domain are stopped, the PLL, the MSI, the HSI16 and the HSE are disabled. LSI and LSE can be kept running.
- Standby mode: VCORE domain powered off.

#### Dynamic voltage scaling

The ultra-low-power STM32L0 Series devices support the dynamic voltage scaling to optimize its power consumption in Run mode. The voltage from the internal low-drop regulator that supplies the logic can be adjusted according to the system's maximum operating frequency and the external voltage supply. There are three power consumption ranges:

- Range 1 (VCore= 1.8V), with the CPU running at up to 32 MHz.
- Range 2 (VCore= 1.5V), with a maximum CPU frequency of 16 MHz.
- Range 3 (VCore= 1.2V), with a maximum CPU frequency limited to 4.2 MHz.

The global power consumption is reduced by using clock gating on unused peripherals.

*Table 19* presents the STM32L0 Series low-power modes summary.



AN4809 Rev 5 23/75

Low-power modes AN4809

Consum-Wakeup Flash Peripherals<sup>(2)</sup> **CPU** Mode Reg. **SRAM Clocks** ption (1) time (µs) (µA/MHz) 200 Range1 All peripherals ON ON ON NA Run Range2 Any 160 available Range3 130 No USB, no MSI ADC, no TSC. **LPRun LPR** ON ON ON 131 KHz 200 3 Other max peripherals available Range1 All peripherals Down to OFF Sleep Range2 ON ON Any 0.36 available 30 Range3 No USB, no ADC, no TSC. MSI LPSleep **LPR** OFF ON ON 200 3.2 131 KHz Other peripherals max

Table 19. STM32L0 Series low-power modes summary

LSI/LSE

LSI/LSE

ON

OFF

available

RTC available

RTC and IWDG

available

**LPR** 

OFF

#### Wakeup sources

The STM32L0 Series devices can get out of the low-power modes on the following events:

#### Sleep mode

Stop

Standby

Any peripheral interrupt/wakeup event

OFF

**DOWN** 

OFF

**OFF** 

#### Stop modes

- Any EXTI line event
- BOR, PVD, COMP, RTC, USB, IWDG, U(S)ART, LPUART, I2C, LPTIM

#### Standby mode

- WKUP pins rising or falling edge
- RTC alarm
- RTC wakeup
- RTC tamper event
- RTC timestamp event
- External reset in NRST pin
- IWDG reset

3.5

50

<sup>1.</sup> The Flash memory can be put in power-down and its clock can be gated off when executing from SRAM.

<sup>2.</sup> Can be clock gated when unused.

AN4809 Low-power modes

#### 4.2 Low-power modes in STM32L4 Series / STM32L4+ Series

#### Low-power modes

The STM32L4 Series / STM32L4+ Series devices offer more flexibility to reduce the global consumption, in addition to the low-power modes from the STM32L0 Series devices. It offers these new modes:

- Stop 0, Stop 1 and Stop 2 modes: SRAMs and all the register content are retained.
   All the clocks in the VCORE domain are stopped, PLL, MSI, HSI16 and HSE are disabled. LSI and LSE can be kept running.
- Shutdown mode: the VCORE domain is powered off. All the clocks in the VCORE domain are stopped, PLL, MSI, HSI16, LSI and HSE are disabled. LSE can be kept running.

In the main Run mode, the power consumption can be reduced by one of the following means:

- Slowing down the system clocks
- Gating the clocks to APB and AHB peripherals when they are unused.

#### Dynamic voltage scaling

The main regulator (MR) has two voltage ranges for dynamic voltage scaling (R1 and R2) used in the Run and Sleep modes.

- Range 1 (VCore = 1.2 V) with the CPU running at up to 80 MHz
- Range 2 (VCore = 1.0 V) with a maximum CPU frequency of 26 MHz. All the peripheral clocks are also limited to 26 MHz.

For STM32L4Rxxx/4Sxxx devices, R1 can be configured in Normal mode or in Boost mode following the R1MODE bit in the PWR\_CR5 register:

- Range 1 boost mode (Vcore = 1.28 V) with the CPU running at up to 120 MHz
- Range 1 normal mode (Vcore = 1.2 V) with the CPU running at up to 80 MHz
- Range 2 (Vcore = 1.0 V) with a maximum CPU frequency of 26 MHz. All the peripheral clocks are also limited to 26 MHz.

The low-power regulator (LPR) is for low-power run, low-power sleep, Stop 1, and Stop 2 modes as well as for the RAM retention in the Standby mode.

*Table 20* summarizes the different low-power modes of STM32L4 Series / STM32L4+ Series. The consumption figures are given for the STM32L476xx devices as indication. For the power consumption figures of other references, refer to the dedicated datasheets.

Table 20. STM32L4 Series / STM32L4+ Series low-power modes summary

| Mode | Reg.       | CPU | Flash<br>(1) | SRAM | Clocks | DMA & Peripherals <sup>(2)</sup> | Consumption (µA/MHz) | Wakeup<br>time<br>(µs) |
|------|------------|-----|--------------|------|--------|----------------------------------|----------------------|------------------------|
| Run  | Range<br>1 | ON  | ON           | ON   | Any    | All peripherals available        | 112 NA               |                        |
|      | Range 2    |     | ON           | ON   | Ally   | All except USB, RNG              | 100                  | 14/4                   |



AN4809 Rev 5 25/75

Low-power modes AN4809

Table 20. STM32L4 Series / STM32L4+ Series low-power modes summary (continued)

| Mode     | Reg.       | СРИ | Flash (1) | SRAM        | Clocks                                                        | DMA & Peripherals <sup>(2)</sup>                                                                  | Consumption (µA/MHz)                    | Wakeup<br>time<br>(μs)                                       |
|----------|------------|-----|-----------|-------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------|
| LPRun    | LPR        | ON  | ON        | ON          | Any<br>except<br>PLL                                          | except All except USB, RNG                                                                        |                                         | Range1:<br>4 µs<br>to<br>range2:<br>64 µs                    |
| Sleep    | Range<br>1 | OFF | ON        | ON          | Any                                                           | All peripherals available                                                                         | 37                                      | 6 cycles                                                     |
| Оісер    | Range<br>2 | OII | ON        | Ö           | Ally                                                          | All except USB, RNG                                                                               | 35                                      | 6 cycles                                                     |
| LPSleep  | LPR        | OFF | ON        | ON          | Any<br>except<br>PLL                                          | All except USB, RNG                                                                               | 40                                      | 6 cycles                                                     |
| Stop 0   | MR         | OFF | OFF       | ON          | LSI/LS<br>E                                                   | LCD, RTC, I/Os, BOR,<br>PVD, PVM, COMPs,<br>IWDG, LPUART, USB,<br>UART, I2C                       | NC                                      | NC                                                           |
| Stop 1   | LPR        | OFF | OFF       | ON          | LSI/LS<br>E                                                   | LCD, RTC, I/Os, BOR,<br>PVD, PVM, COMPs,<br>IWDG, LPUART, USB,<br>UART, I2C                       | - 6.6 w/o<br>RTC<br>- 6.9 w<br>RTC      | <ul><li>4 μs in<br/>SRAM</li><li>6 μs in<br/>Flash</li></ul> |
| Stop 2   | LPR        | OFF | OFF       | ON          | LSI/LS<br>E                                                   | LCD, RTC, I/Os, BOR,<br>PVD, PVM, COMPs,<br>IWDG, LPUART, USB,<br>UART, I2C                       | - 1.1 w/o<br>RTC<br>- 1.4 w<br>RTC      | <ul><li>5 μs in<br/>SRAM</li><li>7 μs in<br/>Flash</li></ul> |
| Standby  | LPR        | OFF | OFF       | SRAM2<br>ON | LSI/LS                                                        | BOR, RTC, IWDG All other peripherals are powered off                                              | - 0.35<br>w/o<br>RTC<br>- 0.65 w<br>RTC | 14                                                           |
|          | OFF        |     |           | Ц           | I/O configuration can<br>be floating, pull-up or<br>pull-down | - 0.12w/o<br>RTC<br>- 0.42w<br>RTC                                                                |                                         |                                                              |
| Shutdown | OFF        | OFF | OFF       | OFF         | LSE                                                           | RTC All other peripherals are powered off I/O configuration can be floating, pull-up or pull-down | – 0.03<br>w/o<br>RTC<br>– 0.33w<br>RTC  | 256                                                          |

<sup>1.</sup> The Flash memory can be put in power-down and its clock can be gated off when executing from SRAM.

26/75 AN4809 Rev 5



<sup>2.</sup> All peripherals can be active or clock gated to save power consumption.

<sup>3.</sup> Typical current at VDD=1.8V, 25°C. The consumption values are provided when running from the SRAM, Flash memory off, 80 MHz in the range 1.26 MHz in range 2.2 MHz in Low-power run / Low-power sleep modes. The values differ for different products, refer to product datasheet for exact values.

AN4809 Low-power modes

#### Wakeup sources

The device can get out of the low-power modes on the following events:

#### Sleep mode

Any peripheral interrupt/wakeup event

#### Stop modes

- Any EXTI line event
- BOR, PVD, PVM, COMP, RTC, USB, IWDG, U(S)ART, LPUART, I2C, SWP, LPTIM, LCD

#### Standby mode

- WKUP pins rising or falling edge
- RTC event
- External reset in NRST pin
- IWDG reset

#### Shutdown mode

- WKUP pins rising or falling edge
- RTC event
- External reset in NRST pin



AN4809 Rev 5 27/75

Peripheral migration AN4809

### 5 Peripheral migration

#### 5.1 STM32Lx product cross-compatibility

STM32L4 Series / STM32L4+ Series embed more peripherals than STM32L0 Series and more instances of the same type or new peripherals. Both series often embed the same versions or very close versions of the same peripherals, allowing an easy migration.

The migration from STM32L0 Series to STM32L4 Series / STM32L4+ Series is easy since its peripherals can be considered as a subset of those of STM32L4 Series / STM32L4+ Series. Inversely, the migration from STM32L4 Series / STM32L4+ Series to STM32L0 Series may need resource sharing to compensate the peripheral instance numbers (DMA, ADC ...).

The migration between the series focuses on common peripherals to all the products. With very close peripheral versions, the software does not need significant development efforts.

The common peripherals may be split in two classes:

- The peripherals strictly identical between the series. They share the same architecture, the same registers and control bits. There is no need to perform any firmware change to keep the same functionality at the application level after migration. All the features and behavior remain the same.
- 2. The new peripheral versions. In general, it implies an upgraded version for STM32L4 Series / STM32L4+ Series. These peripherals require minor changes to support the new features.

*Table 21* gives a global view of the peripherals available as well as the differences between both series. Note that the availability and the number of instances may vary inside each series depending on the devices. Refer to the product datasheets for details.

Table 21. Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series

| Peripherals <sup>(1)</sup> |                                                  | STM32L4 Series /<br>STM32L4+ Series |                             | Comments |
|----------------------------|--------------------------------------------------|-------------------------------------|-----------------------------|----------|
|                            | Cortex <sup>®</sup> -M                           | M0+                                 | M4                          | -        |
| Core                       | Nested vectored interrupt controller (NVIC)      | 39 interrupt channels               | Up to 94 interrupt channels | -        |
|                            | Extended interrupts and events controller (EXTI) | Up to 30 event/<br>interrupt        | Up to 40 event/ interrupt   | -        |

28/75 AN4809 Rev 5

AN4809 Peripheral migration

Table 21. Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|        | Peripherals <sup>(1)</sup>                          | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comments                                                                      |
|--------|-----------------------------------------------------|----------------|-------------------------------------|-------------------------------------------------------------------------------|
|        | Firewall (FW)                                       | ✓              | ✓                                   | Same IP                                                                       |
|        | Cycle redundancy<br>check calculation unit<br>(CRC) | <b>√</b>       | <b>√</b>                            | Same IP                                                                       |
|        | Power control (PWR)                                 | ✓              | ✓                                   | See Section 5.5                                                               |
|        | Reset and clock control (RCC)                       | ✓              | ✓                                   | See Section 5.4                                                               |
|        | General-purpose I/Os (GPIO)                         | Up to 84       | Up to 140<br>(STM32L4Rxxx/4Sxxx)    | Refer to component packages                                                   |
|        | Clock recovery<br>system (CRS)                      | <b>✓</b>       | <b>√</b>                            | Same IP<br>Used for USB XTAL less<br>support                                  |
|        | General purpose DMA (DMA)                           | ✓              | ✓                                   | Same IP<br>See Section 5.3                                                    |
| System | Chrom-Art<br>Accelerator™<br>controller (DMA2D)     | -              | DMA2D                               | Only in<br>STM32L49xxx/L4Axxx and<br>STM32L4Rxxx/4Sxxx                        |
| S      | Flexible static memory controller (FSMC)            | -              | FSMC                                | Only in<br>STM32L47xxx/L48xxx,<br>STM32L49xxx/L4Axxx and<br>STM32L4Rxxx/4Sxxx |
|        | Quad-SPI Interface<br>(QUADSPI)                     | -              | QUADSPI                             | Not available in<br>STM32L4Rxxx/4Sxxx                                         |
|        | OCTOSPI                                             | •              | √ (x2)                              | Only in<br>STM32L4Rxxx/4Sxxx                                                  |
|        | OCTOSPIM                                            | -              | ✓                                   | Only in<br>STM32L4Rxxx/4Sxxx                                                  |
|        | DMAMUX                                              | -              | ✓                                   | Only in<br>STM32L4Rxxx/4Sxxx                                                  |
|        | GFXMMU                                              | -              | ✓                                   | Only in<br>STM32L4Rxxx/4Sxxx                                                  |
|        | DSI                                                 | -              | ✓                                   | Only in<br>STM32L4Rxxx/4Sxxx                                                  |

Peripheral migration AN4809

Table 21. Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|        | Peripherals <sup>(1)</sup>                              | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                                                                   | Comments                                                                                                                                                                                                   |
|--------|---------------------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Voltage reference buffer (VREFBUF)                      | -              | VREFBUF                                                                                                                                                                                                                                               | Voltage reference for ADCs,<br>DACs and external<br>components, available<br>externally on packages with<br>at least 100 pins                                                                              |
|        | Analog-to-digital converters (ADC)                      | <b>√</b> (x1)  | <ul> <li>√</li> <li>x3 for</li> <li>STM32L49xxx/L4Axxx and</li> <li>STM32L47xxx/L48xxx</li> <li>x2 for</li> <li>STM32L41xxx/L42xxx</li> <li>x1 for</li> <li>STM32L45xxx/L46xxx,</li> <li>STM32L43xxx/L44xxx and</li> <li>STM32L4Rxxx/4Sxxx</li> </ul> | See Section 5.9                                                                                                                                                                                            |
|        | Digital-to-analog converter (DAC)                       | ✓              | <b>√</b>                                                                                                                                                                                                                                              | See Section 5.10 Not available on STM32L41xx/L42xxx                                                                                                                                                        |
|        | Comparator (COMP)                                       | √(x2)          | √(x2)                                                                                                                                                                                                                                                 | See Section 5.11                                                                                                                                                                                           |
|        | Operational amplifiers (OPAMP)                          | -              | ✓                                                                                                                                                                                                                                                     | -                                                                                                                                                                                                          |
| Analog | Digital filter for sigma<br>delta modulators<br>(DFSDM) | -              | <b>√</b>                                                                                                                                                                                                                                              | Not available in<br>STM32L43xxx/L44xxx nor<br>STM32L41xxx/L42xxx                                                                                                                                           |
|        | Liquid crystal display controller (LCD)                 | ✓              | <b>√</b>                                                                                                                                                                                                                                              | <ul> <li>Same IP</li> <li>Up to 52 segments for<br/>STM32L0 Series</li> <li>Up to 44 segments for<br/>STM32L4 Series</li> <li>Not available in STM32L4+<br/>Series nor in<br/>STM32L4x1xx/4x2xx</li> </ul> |
|        | Touch sensing controller (TSC)                          | <b>√</b>       | ✓                                                                                                                                                                                                                                                     | Same IP                                                                                                                                                                                                    |
|        | Random number generator (RNG)                           | <b>√</b>       | ✓                                                                                                                                                                                                                                                     | Same IP                                                                                                                                                                                                    |
|        | Advanced encryption standard hardware accelerator (AES) | <b>√</b>       | <b>√</b>                                                                                                                                                                                                                                              | Only on specific part numbers (reference to Table 5)                                                                                                                                                       |
|        | Hash processor<br>(HASH)                                | -              | HASH                                                                                                                                                                                                                                                  | Only in STM32L4A6xx and STM32L4Sxxx                                                                                                                                                                        |
|        | Device electronic signature                             | ✓              | <b>√</b>                                                                                                                                                                                                                                              | Package ID added in<br>STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                 |

30/75 AN4809 Rev 5

AN4809 Peripheral migration

Table 21. Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|                  | Peripherals <sup>(1)</sup>                         | STM32L0 Series         | STM32L4 Series /<br>STM32L4+ Series              | Comments                                                                                                                                                                          |
|------------------|----------------------------------------------------|------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Advanced-control timers                            | -                      | TIM1/TIM8                                        | <ul> <li>GP-Timer with advanced<br/>PWM/Motor Control<br/>capabilities</li> <li>TIM8 only in<br/>STM32L47xxx/<br/>L48xxx/L49xxx/<br/>L4Axxx/4Rxxx/<br/>4Sxxx</li> </ul>           |
|                  | General-purpose timers 4 channels                  | TIM2/TIM3<br>(16 bits) | TIM2/TIM5<br>(32 bits)<br>TIM3/TIM4<br>(16 bits) | <ul> <li>Updated for STM32L4</li> <li>TIM5 and TIM4 only in<br/>STM32L47xxx/<br/>L48xxx/L49xxx/<br/>L4Axxx/4Rxxx/<br/>4Sxxx</li> </ul>                                            |
| Clock and Timers | General-purpose timers 16bits with 1 or 2 channels | TIM21/ TIM22           | TIM15/16/17                                      | <ul><li>Updated for STM32L4</li><li>TIM17 only in<br/>STM32L47xxx/<br/>L48xxx/L49xxx/<br/>L4Axxx/4Rxxx/<br/>4Sxxx</li></ul>                                                       |
|                  | Basic timers                                       | TIM6/TIM7              | TIM6/TIM7                                        | <ul> <li>Updated for STM32L4         Series / STM32L4+ Series</li> <li>TIM7 not available on         STM32L41xxx/L42xxx nor         STM32L45xxx/L46xxx         devices</li> </ul> |
|                  | Low-power timer (LPTIM)                            | <b>✓</b>               | ✓                                                | Same IP                                                                                                                                                                           |
|                  | Independent watchdog (IWDG)                        | ✓                      | ✓                                                | Same IP                                                                                                                                                                           |
|                  | System window watchdog (WWDG)                      | ✓                      | ✓                                                | Same IP                                                                                                                                                                           |
|                  | Real-time clock (RTC)                              | ✓                      | ✓                                                | Same IP                                                                                                                                                                           |

Peripheral migration AN4809

Table 21. Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|              | Peripherals <sup>(1)</sup>                          | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comments                                                                                                                                                                                                                       |
|--------------|-----------------------------------------------------|----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | I2C                                                 | ✓              | ✓                                   | <ul><li>Same IP</li><li>Up to 4 per Series</li></ul>                                                                                                                                                                           |
|              | USART                                               | ✓ (up to 4)    | ✓ (up to 5)                         | Same IP                                                                                                                                                                                                                        |
|              | LPUART                                              | ✓              | ✓                                   | Same IP                                                                                                                                                                                                                        |
|              | Serial peripheral interface (SPI)                   | √ (x2)         | √ (x3)                              | <ul> <li>Upgraded version in<br/>STM32L4 Series /<br/>STM32L4+ Series</li> <li>I2S no longer supported<br/>by SPI but by SAI<br/>interface instead</li> <li>See Section 5.7</li> </ul>                                         |
| Connectivity | Serial audio interface<br>(SAI)                     | -              | ✓                                   | <ul> <li>Also used to support I2S interface</li> <li>Refer to Section 5.7</li> <li>x2 in STM32L49xxx/ L4Axxx, STM32L47xxx/ L48xxx and STM32L4Rxxx/ 4Sxxx</li> <li>x1 in STM32L45xxx/ L46xxx and STM32L44xxx/ L43xxx</li> </ul> |
| Con          | Inter-IC sound (I2S)                                | <b>√</b>       | <b>√</b>                            | <ul><li>I2S by SPI in STM32L0<br/>Series</li><li>I2S by SAI in STM32L4<br/>Series / STM32L4+ Series</li></ul>                                                                                                                  |
|              | Digital camera<br>Interface (DCMI)                  | -              | <b>√</b>                            | Only in STM32L496xx/<br>L4A6xx and<br>STM32L4Rxxx/4Sxxx                                                                                                                                                                        |
|              | USB 2.0 OTG full-<br>speed                          | -              | <b>√</b>                            | - Only in STM32L49xxx/<br>L4Axxx, STM32L47xxx/<br>L48xxx and<br>STM32L4Rxxx/<br>4Sxxx<br>- Refer to Section 5.8.                                                                                                               |
|              | USB 2.0 device full speed Xtal less                 | ✓              | ✓                                   | Refer to Section 5.8.                                                                                                                                                                                                          |
|              | Single wire protocol<br>master interface<br>(SWPMI) | <u>-</u>       | <b>√</b>                            | Not available in<br>STM32L4Rxxx/4Sxxx                                                                                                                                                                                          |
|              | SD/SDIO/MMC card<br>host interface<br>(SDMMC)       | -              | <b>√</b>                            | -                                                                                                                                                                                                                              |

32/75 AN4809 Rev 5

Table 21. Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|                                                                                                                                         | Peripherals <sup>(1)</sup>         | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series | Comments                                                                                                                                                                          |  |
|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Connectivity (continued)                                                                                                                | Controller area<br>network (bxCAN) | -              | ✓                                   | <ul> <li>x2 for STM32L47xxx/<br/>L48xxx and<br/>STM32L49xxx/<br/>L4Axxx</li> <li>x1for STM32L42xxx/<br/>L43xxx, STM32L44xxx/<br/>L45xxx and<br/>STM32L4Rxxx/<br/>4Sxxx</li> </ul> |  |
| Ö                                                                                                                                       | LTDC                               | -              | ✓                                   | Only in STM32L4R7xx/<br>4S7xx/4R9xx/4S9xx                                                                                                                                         |  |
| Color key:  = same peripheral in both series  = peripheral only on STM32L4 Series / STM32L4+ Series  = different versions of peripheral |                                    |                |                                     |                                                                                                                                                                                   |  |

<sup>1. &</sup>quot;√": supported.



AN4809 Rev 5 33/75

Peripheral migration AN4809

### 5.2 Memory mapping

#### 5.2.1 Global memory map

Figure 1 and Figure 2 give the global memory map of each series. New areas in STM32L4 Series / STM32L4+ Series concern the external memory map (FMC, QUADSPI and SRAM2). In the Flash memory address map, there are additional system memory and option bytes areas for dual-banks devices.



Figure 1. STM32L0 Series memory map



Figure 2. STM32L4 Series / STM32L4+ Series memory map

- 1. External memory address range may vary for different part numbers.
- 2. This figure is not applicable on STM32L4Rxxx/4Sxxx.

35/75

Peripheral migration AN4809

#### 5.2.2 Peripherals memory map

There are some differences between the peripheral base address for both series. *Table 22* provides the peripheral address mapping correspondence between STM32L0 Series and STM32L4 Series / STM32L4+ Series. Note that not all the IPs are available in both series depending on the category and feature level of the devices. In case the IP is not present, the associated memory map is reserved.

Table 22. Peripherals memory map

| Peripheral          |        | STM32L0 Series            |      | STM32L4 Series / STM32L4+ Series |  |  |
|---------------------|--------|---------------------------|------|----------------------------------|--|--|
| Periprierai         | Bus    | Base address              | Bus  | Base address                     |  |  |
| GPIOH               |        | 0X5000 1C00 - 0X5000 1FFF |      | 0x4800 1C00 - 0x4800 1FFF        |  |  |
| GPIOE               |        | 0X5000 1000 - 0X5000 13FF |      | 0x4800 1000 - 0x4800 13FF        |  |  |
| GPIOD               | ORT    | 0X5000 0C00 - 0X5000 0FFF |      | 0x4800 0C00 - 0x4800 0FFF        |  |  |
| GPIO C              | IOPORT | 0X5000 0800 - 0X5000 0BFF | AHB2 | 0x4800 0800 - 0x4800 0BFF        |  |  |
| GPIOB               |        | 0X5000 0400 - 0X5000 07FF | Ą    | 0x4800 0400 - 0x4800 07FF        |  |  |
| GPIOA               |        | 0X5000 0000 - 0X5000 03FF |      | 0x4800 0000 - 0x4800 03FF        |  |  |
| AES                 |        | 0X4002 6000 - 0X4002 63FF |      | 0x5006 0000 - 0x5006 03FF        |  |  |
| RNG                 |        | 0X4002 5000 - 0X4002 53FF |      | 0x5006 0800 - 0x5006 0BFF        |  |  |
| TSC                 |        | 0X4002 4000 - 0X4002 43FF |      | 0x4002 4000 - 0x4002 43FF        |  |  |
| CRC                 | AHB    | 0X4002 3000 - 0X4002 33FF | _    | 0x4002 3000 - 0x4002 33FF        |  |  |
| FLASH               | ,      | 0X4002 2000 - 0X4002 23FF | AHB1 | 0x4002 2000 - 0x4002 23FF        |  |  |
| RCC                 |        | 0X4002 1000 - 0X4002 13FF | 4    | 0x4002 1000 - 0x4002 13FF        |  |  |
| DMA1                |        | 0X4002 0000 - 0X4002 03FF |      | 0x4002 0000 - 0x4002 03FF        |  |  |
| USART1              |        | 0X4001 3800 - 0X4001 3BFF | APB2 | 0x4001 3800 - 0x4001 3BFF        |  |  |
| SPI1                |        | 0X4001 3000 - 0X4001 33FF | AFBZ | 0x4001 3000 - 0x4001 33FF        |  |  |
| ADC1                | APB2   | 0X4001 2400 - 0X4001 27FF | AHB2 | 0x5004 0000 - 0x5004 03FF        |  |  |
| Firewall            |        | 0X4001 1C00 - 0X4001 1FFF |      | 0x4001 1C00 - 0x4001 1FFF        |  |  |
| EXTI                |        | 0X4001 0400 - 0X4001 07FF | APB2 | 0x4001 0400 - 0x4001 07FF        |  |  |
| COMP <sup>(1)</sup> |        | 0X4001 0000 - 0X4001 03FF | AFDZ | 0x4001 0200 - 0x4001 03FF        |  |  |
| SYSCFG              |        | 0A4001 0000 - 0A4001 03FF |      | 0x4001 0000 - 0x4001 002F        |  |  |



AN4809 Peripheral migration

Table 22. Peripherals memory map (continued)

| Devinbend        | STM32L0 Series |                           | STM32L4 Series / STM32L4+ Series |                                                                |  |
|------------------|----------------|---------------------------|----------------------------------|----------------------------------------------------------------|--|
| Peripheral       | Bus            | Base address              | Bus                              | Base address                                                   |  |
| LPTIM1           |                | 0X4000 7C00 - 0X4000 7FFF |                                  | 0x4000 7C00 - 0x4000 7FFF                                      |  |
| I2C3             |                | 0X4000 7800 - 0X4000 7BFF |                                  | 0x4000 5C00- 0x4000 5FFF                                       |  |
| DAC1/2           |                | 0X4000 7400 - 0X4000 77FF |                                  | 0x4000 7400 - 0x4000 77FF                                      |  |
| PWR              |                | 0X4000 7000 - 0X4000 73FF |                                  | 0x4000 7000 - 0x4000 73FF                                      |  |
| CRS              |                | 0X4000 6C00 - 0X4000 6FFF |                                  | 0x4000 6000 - 0x4000 63FF                                      |  |
| USB SRAM         |                | 0X4000 6000 - 0X4000 67FF |                                  | 0x4000 6C00 - 0x4000 6FFF                                      |  |
| USB FS           |                | 0X4000 5C00 - 0X4000 5FFF |                                  | 0x4000 6800 - 0x4000 6BFF                                      |  |
| I2C2             |                | 0X4000 5800 - 0X4000 5BFF |                                  | 0x4000 5800 - 0x4000 5BFF                                      |  |
| I2C1             |                | 0X4000 5400 - 0X4000 57FF |                                  | 0x4000 5400 - 0x4000 57FF                                      |  |
| USART5           |                | 0X4000 5000 - 0X4000 53FF |                                  | 0x4000 5000 - 0x4000 53FF                                      |  |
| USART4           | <del>-</del>   | 0X4000 4C00 - 0X4000 4FFF | <del>-</del>                     | 0x4000 4C00 - 0x4000 4FFF                                      |  |
| LPUART1          | APB1           | 0X4000 4800 - 0X4000 4BFF | APB1                             | 0x4000 8000 - 0x4000 83FF                                      |  |
| USART2           |                | 0X4000 4400 - 0X4000 47FF |                                  | 0x4000 4400 - 0x4000 47FF                                      |  |
| SPI2             |                | 0X4000 3800 - 0X4000 3BFF |                                  | 0x4000 3800 - 0x4000 3BFF                                      |  |
| IWDG             |                | 0X4000 3000 - 0X4000 33FF |                                  | 0x4000 3000 - 0x4000 33FF                                      |  |
| WWDG             |                | 0X4000 2C00 - 0X4000 2FFF |                                  | 0x4000 2C00 - 0x4000 2FFF                                      |  |
| RTC +<br>BKP_REG |                | 0X4000 2800 - 0X4000 2BFF |                                  | 0x4000 2800 - 0x4000 2BFF                                      |  |
| LCD              |                | 0X4000 2400 - 0X4000 27FF |                                  | 0x4000 2400 - 0x4000 27FF                                      |  |
| TIMER7           |                | 0X4000 1400 - 0X4000 17FF |                                  | 0x4000 1400 - 0x4000 17FF                                      |  |
| TIMER6           |                | 0X4000 1000 - 0X4000 13FF |                                  | 0x4000 1000 - 0x4000 13FF                                      |  |
| TIMER3           |                | 0X4000 0400 - 0X4000 07FF |                                  | 0x4000 0400 - 0x4000 07FF                                      |  |
| TIMER2           |                | 0X4000 0000 - 0X4000 03FF |                                  | 0x4000 0000 - 0x4000 03FF                                      |  |
| OCTOSPI2         |                |                           |                                  | 0xA000 14000 - 0xA000 17FF                                     |  |
| OCTOSPI1         |                |                           |                                  | 0xA000 1000 - 0xA000 13FF                                      |  |
| FSMC             | NA             | NA                        | AHB3                             | 0xA000 000 - 0xA000 03FF                                       |  |
| SDMMC            |                |                           |                                  | 0x5006 2400 - 0x5006 27FF<br>(for STM32L4Rxxx/4Sxxx)<br>(AHB2) |  |



Table 22. Peripherals memory map (continued)

|                                                                                    |     | STM32L0 Series | <del>- ` ` </del>         | L4 Series / STM32L4+ Series |  |
|------------------------------------------------------------------------------------|-----|----------------|---------------------------|-----------------------------|--|
| Peripheral                                                                         | Bus | Base address   | Bus                       | Base address                |  |
| OCTOSPIM                                                                           |     |                |                           | 0x5006 1C00 - 0x5006 1FFF   |  |
| HASH                                                                               |     |                |                           | 0x5006 0400 - 0x5000 07FF   |  |
| DCMI                                                                               |     |                |                           | 0x5005 0000 - 0x5005 03FF   |  |
| OTG_FS                                                                             |     |                | AHB2                      | 0x5000 0000 - 0x5003 FFFF   |  |
| GPIOI                                                                              |     |                |                           | 0x4800 2000 - 0x4800 23FF   |  |
| GPIOG                                                                              |     |                |                           | 0x4800 1800 - 0x4800 1BFF   |  |
| GPIOF                                                                              |     |                |                           | 0x4800 1400 - 0x4800 17FF   |  |
| GFXMMU                                                                             |     |                |                           | 0x4002 C000 - 0x4002 EFFF   |  |
| DMA2D                                                                              |     |                | AHB1                      | 0x4002 B000 - 0x4002 BBFF   |  |
| DMA2                                                                               |     |                | АПВТ                      | 0x4002 0400 - 0x4002 07FF   |  |
| DMAMUX                                                                             |     |                |                           | 0x4002 0800 - 0x4002 0BFF   |  |
| DSIHOST                                                                            |     |                |                           | 0x4001 6C00 - 0x4001 73FF   |  |
| LCD-TFT                                                                            |     | NA             |                           | 0x4001 6800 - 0x4001 6BFF   |  |
| DFSDM                                                                              |     |                |                           | 0x4001 6000 - 0x4001 67FF   |  |
| SAI2                                                                               | NA  |                |                           | 0x4001 5800 - 0x4001 5BFF   |  |
| SAI1                                                                               | INA |                |                           | 0x4001 5400 - 0x4001 57FF   |  |
| TIM17                                                                              |     |                | APB2                      | 0x4001 4800 - 0x4001 4BFF   |  |
| TIM16                                                                              |     |                | 0x4001 4400 - 0x4001 47FF |                             |  |
| TIM15                                                                              |     |                |                           | 0x4001 4000 - 0x4001 43FF   |  |
| TIM8                                                                               |     |                | 0x4001 3400 - 0x4001 37FF |                             |  |
| TIM1                                                                               |     |                |                           | 0x4001 2C00 - 0x4001 2FFF   |  |
| VREFBUF                                                                            |     |                |                           | 0x4001 0030 - 0x4001 01FF   |  |
| LPTIM2                                                                             |     |                |                           | 0x4000 94000 - 0x4000 97FF  |  |
| I2C4                                                                               |     |                |                           | 0x4000 84000 - 0x4000 87FF  |  |
| OPAMP                                                                              |     |                |                           | 0x4000 7800 - 0x4000 7BFF   |  |
| CAN1                                                                               |     |                | APB1                      | 0x4000 6400 - 0x4000 67FF   |  |
| USART3                                                                             |     |                | AIDI                      | 0x4000 4800 - 0x4000 4BFF   |  |
| SPI3                                                                               |     |                |                           | 0x4000 3C00 - 0x4000 3FFF   |  |
| TIM5                                                                               |     |                |                           | 0x4000 0C00 - 0x4000 0FFF   |  |
| TIM4                                                                               |     |                |                           | 0x4000 0800 - 0x4000 0BFF   |  |
| Color key:  = same address in both series  = different base address in both series |     |                |                           |                             |  |

<sup>1.</sup> COMP and SYSCFG share the same base address in the STM32L0 Series.



Refer to the reference manual or the datasheet for more details.

Note:

An additional SRAM (SRAM2) is available in STM32L4 Series / STM32L4+ Series (64 Kbytes on STM32L4Rxxx/4Sxxx and STM32L49xxx/L4Axxx, 32 Kbytes on STM32L47xxx/L48xxx and STM32L45xxx/L46xxx, 16 Kbytes on STM32L43xxx/L44xxx, 8 Kbytes on STM32L41xxx/L42xxx) and an additional SRAM (SRAM3) of 384 Kbytes is available only in STM32L4Rxxx/4Sxxx.

The SRAM2 includes additional features listed below:

- Maximum performance through ICode bus access without physical remap
- Parity check option (32 bits + 4 bits parity check)
- Write protection with 1 Kbyte granularity
- Read protection (RDP)
- Erase by system reset (option byte) or by software
- Content is preserved in low-power run, low-power sleep, Stop 0, Stop 1 and Stop 2 modes
- Content can be preserved (RRS bit set in the PWR\_CR3 register) in Standby mode (not the case for SRAM1)

## 5.3 Direct memory access controller (DMA)

STM32L0 Series and STM32L4 Series / STM32L4+ Series use the same DMA controller block. STM32L0 Series have one instance of this block with seven independent channels. STM32L4 Series / STM32L4+ Series have two instances of the same block bringing to 14 the number of independent channels.

For STM32L4Rxxx/4Sxxx, each DMA request line is connected in parallel to all the channels of the DMAMUX request line multiplexer. In the rest of the STM32L4 Series / STM32L4+ Series, the DMA request line is connected directly to the peripherals.

The DMAMUX request multiplexer allows a DMA request line to be routed between the peripherals and the DMA controllers of the product. The routine function is ensured by a programmable multi-channel DMA request line multiplexer. Each channel selects a unique DMA request line, unconditionally or synchronously with events from its DMAMUX synchronization inputs.

*Table 23* presents the correspondence between the DMA requests of the peripherals in STM32L0 Series and STM32L4 Series / STM32L4+ Series.

Table 23. DMA request differences migrating STM32L0 Series to STM32L4 Series / STM32L4+ Series

| Peripheral | DMA request | STM32L0 Series       | STM32L4 Series /<br>STM32L4+ Series |
|------------|-------------|----------------------|-------------------------------------|
| ADC        | ADC         | Channel1<br>Channel2 | DMA1_Channel1<br>DMA2_Channel3      |
| DAC        | DAC1        | Channel2             | DMA1_Channel3<br>DMA2_Channel4      |
| DAC        | DAC2        | Channel4             | DMA1_Channel4<br>DMA2_Channel5      |



AN4809 Rev 5 39/75

Table 23. DMA request differences migrating STM32L0 Series to STM32L4 Series / STM32L4+ Series (continued)

| Peripheral | DMA request | STM32L0 Series       | STM32L4 Series /<br>STM32L4+ Series |
|------------|-------------|----------------------|-------------------------------------|
| SPI1       | SPI1_Rx     | Channel2             | DMA1_Channel2<br>DMA2_Channel3      |
| SFII       | SPI1_Tx     | Channel3             | DMA1_Channel3<br>DMA2_Channel4      |
| SPI2       | SPI2_Rx     | Channel4<br>Channel6 | DMA1_Channel4                       |
| OI IZ      | SPI2_Tx     | Channel5<br>Channel7 | DMA1_Channel5                       |
| USART1     | USART1_Rx   | Channel3<br>Channel5 | DMA1_Channel5<br>DMA2_Channel7      |
| USARTI     | USART1_Tx   | Channel2<br>Channel4 | DMA1_Channel4<br>DMA2_Channel6      |
| LICADTO    | USART2_Rx   | Channel5<br>Channel6 | DMA1_Channel6                       |
| USART2     | USART2_Tx   | Channel4<br>Channel7 | DMA1_Channel7                       |
| LDUADT     | LPUART_Rx   | Channel3<br>Channel6 | DMA2_Channel7                       |
| LPUART     | LPUART_Tx   | Channel2<br>Channel7 | DMA2_Channel6                       |
| LIADT4     | UART4_Rx    | Channel2<br>Channel6 | DMA2_Channel5                       |
| UART4      | UART4_Tx    | Channel3<br>Channel7 | DMA2_Channel3                       |
| UART5      | UART5_Rx    | Channel2<br>Channel6 | DMA2_Channel2                       |
| UARTS      | UART5_Tx    | Channel3<br>Channel7 | DMA2_Channel1                       |
| I2C1       | I2C1_Rx     | Channel3<br>Channel7 | DMA1_Channel7<br>DMA2_Channel6      |
| 1201       | I2C1_Tx     | Channel2<br>Channel6 | DMA1_Channel6<br>DMA2_Channel7      |
| 1000       | I2C2_Rx     | Channel5             | DMA1_Channel5                       |
| I2C2       | I2C2_Tx     | Channel4             | DMA1_Channel4                       |
| I2C3       | I2C3_Rx     | Channel3<br>Channel5 | DMA1_Channel3                       |
| .200       | I2C3_Tx     | Channel3<br>Channel5 | DMA1_Channel2                       |

40/75 AN4809 Rev 5

AN4809 Peripheral migration

Table 23. DMA request differences migrating STM32L0 Series to STM32L4 Series / STM32L4+ Series (continued)

| OTHERE FOR CONTRACT C |             |                      |                                     |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------|-------------------------------------|--|--|--|
| Peripheral                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DMA request | STM32L0 Series       | STM32L4 Series /<br>STM32L4+ Series |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM2_UP     | Channel2             | DMA1_Channel2                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM2_CH1    | Channel5             | DMA1_Channel5                       |  |  |  |
| TIM2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TIM2_CH2    | Channel7<br>Channel3 | DMA1_Channel7                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM2_CH3    | Channel1             | DMA1_Channel1                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM2_CH4    | Channel4             | DMA1_Channel7                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM3_UP     | Channel3             | DMA1_Channel3                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM3_CH1    | Channel5             | DMA1_Channel6                       |  |  |  |
| TIM3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TIM3_TRIG   | Channel6             | DMA1_Channel6                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM3_CH3    | Channel2             | DMA1_Channel2                       |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TIM3_CH4    | Channel3             | DMA1_Channel3                       |  |  |  |
| TIM6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TIM6_UP     | Channel2             | DMA1_Channel3<br>DMA2_Channel4      |  |  |  |
| TIM7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TIM7_UP     | Channel4             | DMA1_Channel4<br>DMA2_Channel5      |  |  |  |
| AES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | AES_OUT     | Channel2<br>Channel3 | DMA2_Channel3<br>DMA2_Channel2      |  |  |  |
| ALO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | AES_IN      | Channel1<br>Channel5 | DMA2_Channel1<br>DMA2_Channel5      |  |  |  |

## 5.4 Reset and clock control (RCC)

Figure 3, Figure 4 and Figure 5 represent the clock-trees of high-end devices of STM32L0 Series and STM32L4 Series / STM32L4+ Series. Their architecture are very similar. Both series share the same clock sources: three internal (LSI, HSI and MSI) and two external oscillators (LSE and HSE).

There is a dedicated RC system @ 48 MHz for USB and RNG on some part numbers. They embed a PLL and prescalers to adjust frequencies for the targeted devices. STM32L4 Series / STM32L4+ Series embed additional PLLs (x1 in STM32L45xxx/L46xxx and STM32L43xxx/L44xxx, x2 in STM32L4Rxxx/4Sxxx, STM32L49xxx/L4Axxx and STM32L47xxx/L48xxx) dedicated to the audio interfaces (SAIx), ADC, RNG, SDMMC and OTG FS clock (STM32L4Rxxx/4Sxxx, STM32L49xxx/L4Axxx and STM32L47xxx/L48xxx only).



AN4809 Rev 5 41/75



Figure 3. STM32L0 Series clock tree





Figure 4. STM32L49xxx/L4Axxx clock tree



Figure 5. STM32L4Rxx/4Sxxx clock tree



The main RCC differences in STM32L4 Series / STM32L4+ Series compared to STM32L0 Series are presented in *Table 24*.

Table 24. RCC comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series

|               | RCC                                              | STM32L0 Series                                                                                                                                                                                                                                           | STM32L4 Series / STM32L4+ Series                                                                                                                                                                                                                                                                                    |  |
|---------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|               | MSI                                              | <ul> <li>Multi speed internal RC oscillator</li> <li>Frequency ranges:</li> <li>65.536 kHz, 131.072 kHz,</li> <li>262.144 kHz, 524.288 kHz,</li> <li>1.048 MHz, 2.097 MHz (default value) and 4.194 MHz</li> <li>Factory and user calibration</li> </ul> | <ul> <li>Multi speed internal RC oscillator</li> <li>12 frequency ranges:</li> <li>100 kHz, 200 kHz, 400 kHz, 800 kHz,</li> <li>1 MHz, 2 MHz, 4 MHz (default value),</li> <li>8 MHz, 16 MHz, 24 MHz, 32 MHz and</li> <li>48 MHz</li> <li>Factory and user calibration</li> <li>Auto calibration from LSE</li> </ul> |  |
|               | HSI16                                            | <ul><li>High speed internal 16 MHz RC os</li><li>Factory and user trimmed</li></ul>                                                                                                                                                                      | scillator                                                                                                                                                                                                                                                                                                           |  |
| Clock sources | HSI48                                            | - High speed internal 48 MHz RC oscillator - High precision clock for USB (CRS)                                                                                                                                                                          | <ul> <li>High speed internal 48 MHz RC oscillator (only for STM32L4+ Series, STM32L49xxx/4Axxx, STM32L45xxx/46xxx, STM32L43xxx/46xxx and STM32L41xxx/42xxx)</li> <li>High precision clock for USB (CRS) (not available in STM32L47xxx/L48xxx)</li> </ul>                                                            |  |
|               | LSI                                              | <ul><li>Low speed Internal clock</li><li>32 Hz RC oscillator</li><li>Low-power clock</li></ul>                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                     |  |
|               | HSE                                              | <ul> <li>High speed external clock</li> <li>1 to 24 MHz</li> <li>From external clock or external crystal/ceramic resonator</li> </ul>                                                                                                                    | - High speed external clock - 4 to 48 MHz - From external clock or external crystal/ceramic resonator                                                                                                                                                                                                               |  |
|               | LSE – Low-power – Configurable drive/consumption |                                                                                                                                                                                                                                                          | <ul> <li>Low speed external clock</li> <li>32.768 kHz</li> <li>Configurable drive/consumption</li> <li>Available in backup domain (VBAT)</li> </ul>                                                                                                                                                                 |  |



Table 24. RCC comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|                      | RCC                            | STM32L0 Series                                                                                        | STM32L4 Series / STM32L4+ Series                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|----------------------|--------------------------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                      | Input<br>frequency             | 2 MHz to 24 MHz                                                                                       | 4 MHz to 16 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                      | Max output<br>Frequency        | 48 MHz                                                                                                | 80 MHz (and 120 MHz only in STM32L4Rxxx/4Sxxx)                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                      | Sources                        | HSI16, HSE                                                                                            | HSI16, HSE, MSI                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| TTd                  | Features                       | - One PLL with single output - PLL multiplication/division factors are different from STM32 L4 Series | <ul> <li>PLL embedded depending on devices</li> <li>Main PLL for system PLL         x1 for STM32L45xxx/L46xxx and         STM32L43xxx/L44xxx         x2 for STM32L4Rxxx/4Sxxx,         STM32L49xxx/L4Axxx and         STM32L47xxx/L48xxx         for SAI, ADC, RNG, SDMMC and OTG         FS clock</li> <li>Each PLL can provide up to 3         independent outputs</li> <li>PLL multiplication/division factors are         different from STM32L0 Series</li> </ul> |  |  |
| ock                  | Sources                        | MSI, H                                                                                                | SI, HSE or PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| System Clock         | Frequency<br>(see<br>Table 25) | <ul><li>Up to 32 MHz</li><li>2.1 MHz after reset using MSI</li></ul>                                  | <ul><li>Up to 80 MHz (or 120MHz for<br/>STM32L4Rxxx/4Sxxx)</li><li>4 MHz after reset using MSI</li></ul>                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                      | RTC clock source               | LSI, L                                                                                                | SE or HSE/32                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| MCU clock<br>outputs |                                | MCO: SYSCLK, HSI16, HSI48,<br>MSI, HSE, PLL, LSI, LSE                                                 | <ul> <li>MCO: SYSCLK, HSI16, MSI, HSE, PLL, LSI, LSE</li> <li>HSI48 for STM32L45xxx/L46xxx, STM32L43xxx/L44xxx, STM32L41xxx/L42xxx, STM32L41xxx/L42xxx, STM32L49xxx/L4Axxx and STM32L4Rxxx/L4Axxx</li> <li>LSCO: LSI, LSE</li> </ul>                                                                                                                                                                                                                                   |  |  |
|                      | lock Security<br>ystem (CSS)   | Available                                                                                             | on LSE and HSE                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                      | TIMERS for clock leasurement   | TIM21                                                                                                 | TIM15/16/17                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |



#### Clock source frequency versus voltage scaling

The maximum system clock frequency and the Flash memory wait state depends on the selected voltage range VCORE and also on VDD for STM32L0 Series. *Table 25* gives the different clock source frequencies depending on the product voltage range.

Table 25. Performance versus V<sub>CORE</sub> ranges<sup>(1)</sup>

| CPU Power VCORE Typical Max frequency |            |                       | ency (       | MHz)    |         |         |         |         |         |                       |
|---------------------------------------|------------|-----------------------|--------------|---------|---------|---------|---------|---------|---------|-----------------------|
| performance                           | performanc | range value (V)       | value<br>(V) | 5<br>WS | 4<br>WS | 3<br>WS | 2<br>WS | 1<br>WS | 0<br>WS | V <sub>DD</sub> range |
|                                       |            |                       | STM32        | 2L0 Se  | eries   |         |         |         |         |                       |
| High                                  | Low        | 1                     | 1.8          | -       | -       | -       | -       | 32      | 16      | 1.71 - 3.6            |
| Medium                                | Medium     | 2                     | 1.5          | -       | -       | -       | -       | 16      | 8       | 1.65 - 3.6            |
| Low                                   | High       | 3                     | 1.2          | -       | -       | -       | -       | 4.2     | 4.2     | 1.00 - 3.0            |
|                                       |            |                       | STM32        | 2L4 Se  | ries    |         |         |         |         |                       |
| High                                  | Medium     | 1                     | 1.2          | -       | 80      | 64      | 48      | 32      | 16      | NA                    |
| Medium                                | High       | 2                     | 1.0          | -       | 26      | 26      | 18      | 12      | 6       | NA                    |
|                                       |            |                       | STM32        | L4+ S   | eries   |         |         |         |         |                       |
| High                                  | Medium     | 1<br>(boost<br>mode)  | 1.28         | 120     | 100     | 80      | 60      | 40      | 20      | NA                    |
| riigii                                | Mediuiii   | 1<br>(normal<br>mode) | 1.2          | -       | -       | 80      | 60      | 40      | 20      | NA                    |
| Medium                                | High       | 2                     | 1.0          | -       | -       | -       | 26      | 16      | 8       | NA                    |

<sup>1.</sup> WS = wait state.



AN4809 Rev 5 47/75

## 5.5 Power control (PWR)

Figure 6 and Figure 7 present the power supply for both series. The differences are summarized in *Table 26*. For the low-power mode comparison, refer to Section 4.



Figure 6. STM32L0 Series power supply

1. This figure is not applicable on STM32L4Rxxx/4Sxxx.





Figure 7. STM32L4 Series power supply





Figure 8. STM32L4+ Series power supply overview



*Table 26* compares the power features for both series.

Table 26. PWR comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series

|                | PWR              | STM32L0 Series                                                                                                                                                                                            | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                                                                                                                                                                     |  |  |  |
|----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                |                  | <ul><li>VDD is the external power supply for I/Os and internal regulator</li><li>It is provided externally through VDD pins</li></ul>                                                                     |                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|                | VDD              | <ul> <li>1.8 V at power-on<br/>or 1.65 V at power-down<br/>to 3.6 V when the BOR is available</li> <li>VDD = 1.65 V to 3.6 V when BOR is not<br/>available</li> </ul>                                     | 1.71 to 3.6 V                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                | VDDIO2           | -                                                                                                                                                                                                         | <ul> <li>- 1.08 V to 3.6 V</li> <li>- VDDIO2 is the external power supply for 14 I/Os (Port G[15:2])</li> <li>- The VDDIO2 voltage level is independent from the VDD voltage and can be tied to ground when PG[15:2] are not used</li> </ul>                                                                                                            |  |  |  |
|                | VCore            | <ul> <li>VCORE is the power supply for digital peri</li> <li>It is generated by an internal voltage regul</li> <li>Three VCORE ranges can be selected by frequency</li> </ul>                             | tor                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| S              |                  | 1.2 to 1.8 V                                                                                                                                                                                              | 1.0 to 1.28 V                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Power supplies | Vssa,<br>Vdda    | VDDA is the external analog power supply for ADC, DAC, voltage reference buffer, operational amplifiers and comparators.                                                                                  |                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Power          |                  | <ul> <li>1.8 V at power-on or 1.65 V at power-down to 3.6 V when BOR is available</li> <li>VSSA, VDDA = 1.65 to 3.6 V when BOR is not available</li> <li>For DAC min VDDA = 1.8 V</li> </ul>              | From - 1.62 V (ADCs/COMPs) - 1.8 V (DACs/OPAMPs) - 2.4 V (VREFBUF) to 3.6 V                                                                                                                                                                                                                                                                             |  |  |  |
|                | VREF-,<br>VREF+  | <ul> <li>VREF+ is the input reference voltage for A the internal voltage reference buffer when</li> <li>VREF- and VREF+ pins are not available of they are bonded to VSSA and VDDA, responded.</li> </ul> | enabled on all packages. When not available,                                                                                                                                                                                                                                                                                                            |  |  |  |
|                | V <sub>BAT</sub> | NA                                                                                                                                                                                                        | <ul> <li>1.55 to 3.6 V</li> <li>VBAT is the power supply for RTC, external clock 32 kHz oscillator and backup registers (through power switch) when VDD is not present</li> <li>When VDD is present, it is possible to charge the external battery on VBAT through an internal resistance</li> <li>It is automatically disabled in VBAT mode</li> </ul> |  |  |  |



Table 26. PWR comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

|                          | PWR                    | STM32L0 Series                                                                                                                                                                                                                                         | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                                                                  |  |  |  |  |
|--------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                          | VLCD                   |                                                                                                                                                                                                                                                        | <ul> <li>2.5 to 3.6 V</li> <li>The LCD controller can be powered either externally through VLCD pin, or<br/>internally from an internal voltage generated by the embedded step-up converter</li> </ul>                                               |  |  |  |  |
|                          | VDD_USB                | <ul> <li>3.0 to 3.6V</li> <li>VDDUSB is the external independent power supply for USB transceivers</li> <li>The VDDUSB voltage level is independent from the VDD voltage and should preferably be connected to VDD when the USB is not used</li> </ul> |                                                                                                                                                                                                                                                      |  |  |  |  |
| Power supply (continued) | VDDDSI                 | NA                                                                                                                                                                                                                                                     | <ul> <li>Available only on<br/>SM32L4R9xx/4S9xx</li> <li>Independent DSI power supply<br/>dedicated for the DSI regulator and<br/>the MIPI D-PHY</li> <li>This supply must be connected to<br/>the global VDD</li> </ul>                             |  |  |  |  |
| Power supp               | VCAPDSI                | NA                                                                                                                                                                                                                                                     | <ul> <li>Available only on<br/>SM32L4R9xx/4S9xx</li> <li>Output of the DSI regulator (1.2 V)<br/>which must be connected<br/>externally to VDD12DSI</li> </ul>                                                                                       |  |  |  |  |
|                          | VDD12DSI               | NA                                                                                                                                                                                                                                                     | <ul> <li>Available only on<br/>SM32L4R9xx/4S9xx</li> <li>It is used to supply the MIPI D-<br/>PHY, and to supply the clock and<br/>data lanes pins</li> <li>An external capacitor of 2.2 μF<br/>must be connected on the<br/>VDD12DSI pin</li> </ul> |  |  |  |  |
| Bat                      | ttery backup<br>domain | NA                                                                                                                                                                                                                                                     | To retain the content of the Backup registers and supply the RTC function when VDD is turned off, the VBAT pin can be connected to an optional backup voltage supplied by a battery or by another source                                             |  |  |  |  |
| Voltage<br>regulator     |                        | <ul> <li>Range 1 (VCore 1.8V);</li> <li>HCLK up to 32 MHz</li> <li>Range 2 (VCore 1.5V);</li> <li>HCLK @ 16 MHz</li> <li>Range 3 (VCore 1.2V);</li> <li>HCLK @ 4.2 MHz</li> </ul>                                                                      | <ul> <li>Range 1 boost mode (Vcore = 1.28 V); HCLK up to 120 MHz (applicable only on STM32L4Rxxx/4Sxxx)</li> <li>Range 1 normal mode (default) (VCore= 1.2 V); HCLK up to 80 MHz</li> <li>Range 2 (VCore = 1.0 V); HCLK @ 26 MHz</li> </ul>          |  |  |  |  |



Table 26. PWR comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

| PWR                     | STM32L0 Series                                                                                                                                                                                                                    | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                                                                                                                                                       |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | Integrated POR / PDR circuitry @ 1.5 V                                                                                                                                                                                            | Integrated POR / PDR circuitry                                                                                                                                                                                                                                                                                                            |
|                         | Brownout reset (BOR)                                                                                                                                                                                                              | Brownout reset (BOR)                                                                                                                                                                                                                                                                                                                      |
| Power supply supervisor | PVD monitors VDDA/VDD                                                                                                                                                                                                             | <ul> <li>4 peripheral voltage monitoring<br/>(PVM)</li> <li>PVM1 for V<sub>DDUSB</sub></li> <li>PVM2 for V<sub>DDIO2</sub></li> <li>PVM3/PVM4 for<br/>V<sub>DDA</sub> (~1.65V/ ~2.2V)</li> </ul>                                                                                                                                          |
| Low-power<br>modes      | <ul> <li>Sleep mode</li> <li>Low-power Run mode up to 131 KHz</li> <li>Low-power Sleep mode up to 131 KHz</li> <li>Stop mode</li> <li>Standby mode (V<sub>CORE</sub> domain powered off)</li> <li>Refer to Section 4.1</li> </ul> | <ul> <li>Sleep mode</li> <li>Low-power Run mode up to 2 MHz</li> <li>Low-power Sleep mode up to 2 MHz</li> <li>Stop 0, Stop 1 and Stop 2 modes</li> <li>Standby mode (V<sub>CORE</sub> domain powered off)</li> <li>Shutdown mode (V<sub>CORE</sub> domain powered off and power monitoring off)</li> <li>Refer to Section 4.2</li> </ul> |
| External SMPS           | NA                                                                                                                                                                                                                                | <ul> <li>Support for external SMPS for<br/>high-power efficiency.</li> <li>Refer to AN4978.</li> </ul>                                                                                                                                                                                                                                    |



## 5.6 Flash memory

*Table 27* presents the difference between the Flash memory interface of STM32L0 Series and STM32L4 Series / STM32L4+ Series.

The STM32L4 Series / STM32L4+ Series devices instantiate a different Flash module both in terms of architecture, technology and interface. Consequently the STM32L4 Flash memory programming procedures and registers are different from the ones in STM32L0 Series. Any code written for the Flash interface in STM32L0 Series needs to be rewritten to run on STM32L4 Series / STM32L4+ Series.

For more information on programming, erasing and protection of the STM32L4 Flash memory, refer to STM32L4 Series / STM32L4+ Series reference manuals (RM0351, RM0394, RM0392 and RM0432).

Table 27. FLASH differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series

| FLASH                         | STM32L0 Series                                                                                                                                                                          | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Main/<br>Program memory       | <ul> <li>Up to 192 Kbytes in one or two banks (only in STM32L07/8x devices)</li> <li>Word: 32 bits</li> <li>Page: 128 bytes (316 bytes)</li> <li>Sector: 32 pages (4 Kbytes)</li> </ul> | <ul> <li>Up to 1 Mbyte Split in 2 Banks</li> <li>Word: 64 bits</li> <li>Page: 2 Kbytes (8 rows of 256 bytes)</li> <li>Bank: up to 256 pages of 2 Kbytes (512 Kbytes)</li> <li>For STM32L4Rxxx/4Sxxx: Up to 2 Mbytes Split in 2 Banks Single-bank mode: word = 64 bits Up to 256 pages of 8 Kbytes Dual-bank mode: word = 128 bits Up to 256 page of 4 Kbytes</li> </ul> |
| Flash empty check             | In Cat. 1 only                                                                                                                                                                          | - ECC - Flash empty check (only for STM32L45xxx/46xxx, STM32L43xxx/44xxx, STM32L41xxx/L42xxx, STM32L49xxx/4Axxx and STM32L4Rxxx/4Sxxx)                                                                                                                                                                                                                                  |
| ECC                           | <ul><li>6 bits/word (32bits)</li><li>One error correction</li><li>Two errors detection</li></ul>                                                                                        | <ul><li>8 bits for 64-bit double word</li><li>One error correction</li><li>Two errors detection</li></ul>                                                                                                                                                                                                                                                               |
| Wait State                    | 0 or 1                                                                                                                                                                                  | Up to 5 (depending on the Core voltage and frequency)                                                                                                                                                                                                                                                                                                                   |
| ART Accelerator <sup>TM</sup> | NA                                                                                                                                                                                      | <ul> <li>Prefetch on ICODE</li> <li>Instruction Cache:</li> <li>32 cache lines of 4 x 64 bits on ICode (1 Kbyte RAM)</li> <li>Data Cache:</li> <li>8 cache lines of 4 x 64 bits on DCode (256 bytes RAM)</li> </ul>                                                                                                                                                     |



Table 27. FLASH differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

| FLASH                                       | STM32L0 Series                                                                                  | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                                                              |
|---------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data EEPROM memory                          | <ul><li>Up to 6 Kbytes in one or two banks</li><li>Write Access byte, half word, word</li></ul> | NA<br>(can be emulated by SW)                                                                                                                                                                                                                    |
| System memory                               | Up to 8 Kbytes                                                                                  | 28 Kbytes per bank                                                                                                                                                                                                                               |
| One time programmable (OTP)                 | -                                                                                               | 1 KByte (Bank1 only)                                                                                                                                                                                                                             |
| Option bytes                                | 96 bytes (factory) + 32 bytes (user)                                                            | 32 bytes per bank                                                                                                                                                                                                                                |
| Erase granularity                           | Page erase: 128 bytes                                                                           | Page erase (2 Kbytes), Bank erase and Mass erase (both banks)                                                                                                                                                                                    |
|                                             | <ul><li>Level 0 no protection</li><li>RDP = 0xAA</li></ul>                                      |                                                                                                                                                                                                                                                  |
| Readout protection (RDP)                    | <ul><li>Level 1 memory protection</li><li>RDP!= (Level 2 &amp; Level 0)</li></ul>               |                                                                                                                                                                                                                                                  |
|                                             | Level 2 RDP                                                                                     | o = 0xCC <sup>(1)</sup>                                                                                                                                                                                                                          |
| Proprietary code readout protection (PCROP) | Protection set by sector (4 Kbytes)                                                             | <ul> <li>One protected area per bank</li> <li>Granularity: 64 bit</li> <li>PCROP_RDP option: PCROP area preserved when RDP level decreased</li> <li>For STM32L4Rxxx/4Sxxx: Dual bank: 1 PCROP area per bank Single bank: 2 PCROP area</li> </ul> |
| Write protection<br>(WRP)                   | <ul><li>Single protected area</li><li>Protection set by sector (4 Kbytes)</li></ul>             | <ul> <li>2 Write protection areas per bank</li> <li>Granularity: 2 Kbytes</li> <li>For STM32L4Rxxx/4Sxxx:</li> <li>Dual bank: 2 areas per bank</li> <li>Single bank: 4 areas</li> </ul>                                                          |
| Option bytes                                | Global options:  – RDP protection  – User option bytes  – Write/PCROP sectors number            | Global options:  - RDP protection  - User option bytes Bank options:  - PCROP start@  - PCROP end@  - Write Protection Area 1 @  - Write Protection Area 2 @  - DBANK  (only for STM32L4Rxxx/4Sxxx)  - DB1M  (only for STM32L4Rxxx/4Sxxx)        |

<sup>1.</sup> Memory read protection Level 2 is an irreversible operation. When the Level 2 is activated, the level of protection cannot be decreased to Level 0 or Level 1.



# 5.7 Serial peripheral interface (SPI)/ IC to IC sound (I2S) serial audio interface (SAI)

STM32L4 Series / STM32L4+ Series and STM32L0 Series implement a very close version of the SPI peripheral. STM32L4 Series / STM32L4+ Series have an upgraded version of the IP without the support of the I2S interface. In STM32L4 Series / STM32L4+ Series, the I2S is supported by the SAI interface (see Section 5.7).

The SPI peripherals in both series share the following features:

- Master or slave operation
- Full-duplex synchronous transfers on three lines
- Half-duplex synchronous transfer on two lines (with bidirectional data line)
- Simplex synchronous transfers on two lines (with unidirectional data line)
- Multimaster mode capability
- 8 master mode baud rate prescalers up to fPCLK/2.
- Slave mode frequency up to fPCLK/2.
- NSS management by hardware or software for both master and slave: dynamic change of master/slave operations
- Programmable clock polarity and phase
- Programmable data order with MSB-first or LSB-first shifting
- Dedicated transmission and reception flags with interrupt capability
- SPI bus busy status flag
- SPI Motorola support
- Hardware CRC feature for reliable communication:
  - CRC value can be transmitted as last byte in Tx mode
  - Automatic CRC error checking for last received byte
- Master mode fault, overrun flags with interrupt capability
- CRC Error flag
- SPI TI mode support



The differences between both series are listed in Table 28.

Table 28. SPI differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series

| SPI          | STM32L0 Series                                                       | STM32L4 Series /<br>STM32L4+ Series                                                                       |
|--------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Instances    | <ul><li>SPI1 w/o I2S support</li><li>SPI2 with I2S support</li></ul> | SPI1, SPI2, SPI3. All without I2S support                                                                 |
| Features     | I2S support                                                          | <ul><li>I2S feature is not supported by SPI2</li><li>SAI interfaces are available instead</li></ul>       |
| Data size    | 8-bits or 16 bits                                                    | <ul><li>Programmable from 4 to 16 bits</li><li>Data packing</li></ul>                                     |
| Data buffer  | NA                                                                   | 32-bit Tx & Rx FIFOs (up to 4 data frames)                                                                |
| Data packing | NA                                                                   | <ul><li>YES</li><li>8-bit, 16-bit or 32-bit data access,<br/>programmable FIFOs data thresholds</li></ul> |
| Speed        | Up to 16 Mbits/s slave and master modes                              | <ul><li>Up to 40 Mbits/s in master mode</li><li>Up to 24 Mbits/s in slave mode</li></ul>                  |

The I2S protocol is supported by the SPI peripheral in STM32L0 Series. STM32L4 Series / STM32L4+ Series embed a new SAI peripheral instead. The SAI peripheral brings more flexibility and improves the robustness of communication in the Slave mode compared to the I2S peripheral (in case of the data clock glitch for example). *Table 29* presents the main differences between both implementations.



Table 29. Audio interface support in STM32L0 Series and STM32L4 Series / STM32L4+ Series

| I2S             | STM32L0 Series (SPI)                                                                                                                                                                               | STM32L4 Series / STM32L4+ Series (SAI)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instances       | 1 (with SPI2 peripheral)                                                                                                                                                                           | <ul> <li>x2 in STM324Rxxx/4Sxx,<br/>STM32L49xxx/L4Axxx and<br/>STM32L47xxx/L48xxx (SAI1 and SAI2)</li> <li>x1 in STM32L45xxx/L46xxx and<br/>STM32L43xxx/L44xxx (SAI1)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |
| Architecture    | <ul> <li>I2S supported by SPI peripheral.</li> <li>Support Master and slave modes</li> </ul>                                                                                                       | <ul> <li>Two independent audio sub-blocks (per SAI) which can be transmitters or receivers with their respective FIFO</li> <li>Master/Slave configuration independent for both audio sub-blocks (2 sub-blocks per SAI peripherals)</li> <li>Synchronous or asynchronous mode between the audio sub-blocks. Possible synchronization between multiple SAIs</li> <li>Frame synchronization active level configurable (offset, bit length, level)</li> <li>Stereo/Mono audio frame capability</li> <li>Mute mode</li> <li>PDM interface for STM32L4Rxxx/L4Sxxx</li> </ul> |
| Pins<br>mapping | <ul> <li>SD (serial data) =&gt; on MOSI pin</li> <li>WS (word select) =&gt; on NSS pin</li> <li>CK (serial clock) =&gt; on SCK pin</li> <li>MCLK</li> </ul>                                        | SD, SCK, FS, MCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Data<br>formats | <ul> <li>16-bit data packed in a 16-bit frame</li> <li>16-bit data packed in a 32-bit frame</li> <li>24-bit data packed in a 32-bit frame</li> <li>32-bit data packed in a 32-bit frame</li> </ul> | <ul><li>8-bit, 10-bit, 16-bit, 20-bit, 24-bit, 32-bit</li><li>LSB or MSB first</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Standards       | <ul><li>I2S Philips</li><li>I2S MSB justified</li><li>I2S LSB justified</li><li>PCM</li></ul>                                                                                                      | <ul> <li>I2S Philips</li> <li>I2S MSB justified</li> <li>IS2 LSB justified</li> <li>PCM/DSP</li> <li>TDM (Time Division Multiplexing) up to 16 channels)</li> <li>AC'97 (Intel)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                             |

AN4809 Peripheral migration

#### 5.8 **USB**

STM32L45xxx/L46xxx, STM32L43xxx/L44xxx, STM32L41xxx/L42xxx and STM32L0 Cat.3 and Cat.5 implement the same USB 2.0 device full-speed controller. This version supports a crystal-less device by using a clock recovery system (CRS) peripheral. The CRS provides a precise clock to the USB peripheral. The synchronization signal is derived from the start-of-frame (SOF) packet signalization on the USB bus, which is sent by a USB host at precise 1 ms intervals.

STM32L4Rxxx/4Sxxx, STM32L49xxx/L4Axxx and STM32L47xxx/L48xxx devices embed a new 2.0 USB-OTG full speed version with integrated PHY.

The key differences between both USB peripherals are listed in *Table 30*.

Table 30. USB peripheral comparison

| USB              | STM32L0 Cat. 3 and Cat. 5<br>STM32L45xxx/L46xxx,<br>STM32L43xxx/L44xxx and<br>STM32L41xxx/L42xxx                                                                    | STM32L4Rxxx/4Sxxx,<br>STM32L49xxx/L4Axxx and<br>STM32L47xxx/L48xxx                                                                              |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul> <li>Universal Serial Bus Revision 2.0, including Link Power Management (LPM) support</li> <li>Full-Speed (FS, 12-Mbps) and Low-Speed (LS, 1.5-Mbps)</li> </ul> |                                                                                                                                                 |
|                  | NA                                                                                                                                                                  | <ul><li>Full support for the USB On-The-Go<br/>(USB OTG)</li><li>Up to 12 host channels</li></ul>                                               |
|                  | Embedded FS USB Device PHY                                                                                                                                          | Embedded FS OTG PHY                                                                                                                             |
| Features         | FS mode:  - 1 bidirectional control endpoint  - 7 IN endpoints (Bulk, Interrupt, Isochronous)  - 7 OUT endpoints (Bulk, Interrupt, Isochronous)                     | FS mode:  - 1 bidirectional control endpoint  - 5 IN endpoints (Bulk, Interrupt, Isochronous)  - 5 OUT endpoints (Bulk, Interrupt, Isochronous) |
|                  | Battery charging detection (BCD)                                                                                                                                    | Attach detection protocol (ADP)     Battery charging detection (BCD)                                                                            |
|                  | Independent VDDUSB power supply allowing lower VDD while using USB                                                                                                  |                                                                                                                                                 |
| Buffer<br>memory | 1024 bytes (endpoint buffers and buffer descriptors structure)                                                                                                      | Device mode:<br>1.25 Kbyte data FIFOs                                                                                                           |
| Low-power modes  | <ul><li>USB suspend and resume</li><li>Link power management<br/>(for STM32L0 Series only)</li></ul>                                                                | - USB suspend and resume - Link power management (LPM)                                                                                          |



AN4809 Rev 5 59/75

## 5.9 Analog-to-digital converters (ADC)

The ADC converters embedded in both series share advanced options such as:

- Several resolutions
- Auto-calibration
- Analog watchdogs
- Over-sampler up to 256x
- Efficient low-power mode

STM32L0 Series embed one ADC instance while STM32L4 Series / STM32L4+ Series embed three of them. The two instances (ADC1 and ADC2) can be coupled to allow dual mode operation.

*Table 31* presents the differences between the ADC peripheral of the STM32L0 Series and the STM32L4 Series.

Table 31. ADC differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series

| ADC                          | STM32L0 Series                                                                           | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                  |
|------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADC Type                     | SAR structure                                                                            | SAR structure                                                                                                                                                                        |
| Instances                    | ADC1                                                                                     | <ul> <li>x3 for STM32L49xxx/L4Axxx and STM32L47xxx/L48xxx</li> <li>x2 for STM32L41xxx/L42xxx</li> <li>x1 for STM32L4Rxxx/4Sxxx, STM32L45xxx/L46xxx and STM32L43xxx/L44xxx</li> </ul> |
| Max Sampling freq<br>@12bits | 1.14 MSPS                                                                                | <ul><li>5.33 MSPS (Fast channels)</li><li>4.21 MSPS (Slow channels)</li></ul>                                                                                                        |
| Max Sampling freq<br>@10bits | 1.23 MSPS                                                                                | 6.25 MSPS                                                                                                                                                                            |
| Number of external channels  | 16 external analog inputs                                                                | For each ADC:  - Up to 5 fast external channels  - Up to 11 slow external channels                                                                                                   |
| Number of internal channels  | <ul><li>Temperature sensor</li><li>Reference voltage</li><li>VLCD power supply</li></ul> | <ul><li>Temperature sensor</li><li>Reference voltage</li><li>Power supply</li><li>DAC1, DAC2 output</li></ul>                                                                        |
| Resolution                   | 12,10,8 or 6 bits configurable resolution                                                | 12,10,8 or 6 its configurable resolution                                                                                                                                             |
| Conversion modes             | Single / continuous / scan / discontinuous/ dual mode                                    | Single / continuous / scan / discontinuous/ dual mode                                                                                                                                |
| Dual ADC mode                | NA                                                                                       | ADC1+ADC2                                                                                                                                                                            |
| DFSDM redirection            | NA                                                                                       | Available for STM32L45xxx/L46xxx,<br>STM32L49xxx/L4Axxx and<br>STM32L4Rxxx/4Sxxx                                                                                                     |
| DMA                          | Yes                                                                                      | Yes                                                                                                                                                                                  |
|                              |                                                                                          |                                                                                                                                                                                      |

60/75 AN4809 Rev 5

AN4809 Peripheral migration

Table 31. ADC differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series (continued)

| ADC                | STM32L0 Series                                                                                       | STM32L4 Series /<br>STM32L4+ Series                                                                             |
|--------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| SW trigger         | Yes                                                                                                  | Yes                                                                                                             |
| HW trigger         | <ul><li>Internal timers<br/>(TIM2, TIM3, TIM6, TIM21,<br/>TIM22)</li><li>GPIO input events</li></ul> | <ul><li>Internal timers<br/>(TIM1, TIM2, TIM3, TIM4, TIM6,<br/>TIM8, TIM15)</li><li>GPIO input events</li></ul> |
| Supply requirement | 1.65 V to 3.6 V                                                                                      | <ul><li>1.62 V to 3.6 V</li><li>Independent power supply<br/>(VDDA)</li></ul>                                   |
| Reference Voltage  | External                                                                                             | External or Internal (2.048 V or 2.5 V)                                                                         |
| Input range        | VSSA <= VIN <= VDDA (analog ground and power supply)                                                 | VREF- <= VIN <= VREF+ (VREF- = VSSA and 1.62 V ≤ VREF+ ≤ VDDA)                                                  |



## 5.10 Digital-to-analog converter (DAC)

The DAC of both series shares the following features:

- Left or right data alignment in 12-bit mode
- Synchronized update capability
- Noise-wave and Triangular-wave generation
- Dual DAC channel for independent or simultaneous conversions
- DMA capability for each channel including DMA underrun error detection
- External triggers for conversion
- Input voltage reference
- Vpef.

STM32L4 Series / STM32L4+ Series implement an enhanced DAC version compared to the STM32L0 Series one. *Table 32* shows these differences.

Table 32. DAC differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series

| DAC                 | STM32L0 Series                                                                                                                                                                 | STM32L4 Series / STM32L4+ Series                                                                                                                                                                                                         |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instances           | <ul> <li>x1 on STM32L05xxx and<br/>STM32L06xxx</li> <li>x2 on STM32L07xxx and<br/>STM32L08xxx</li> <li>No DAC for other devices</li> </ul>                                     | <ul> <li>x2 on STM32L4Rxxx/4Sxxx,<br/>STM32L49xxx/L4Axxx,<br/>STM32L47xxx/L48xxx and<br/>STM32L43xxx/L44xxx</li> <li>x1 on STM32L45xxx/L46xxx devices</li> </ul>                                                                         |
| Resolution          | 12-bit                                                                                                                                                                         | 12-bit                                                                                                                                                                                                                                   |
| Features            | <ul> <li>Left or right data alignment in 12-bit mode</li> <li>Noise-wave and Triangular-wave general</li> <li>Dual DAC channel for independent or since</li> <li>NA</li> </ul> | ation                                                                                                                                                                                                                                    |
| External<br>trigger | - TIM6 TRGO - TIM3 TRGO - TIM3 CH3 - TIM21 TRGO - TIM2 TRGO - TIM7 TRGO - EXTI line9 - SW TRIG                                                                                 | - TIM6 TRGO - TIM8 TRGO <sup>(1)</sup> - TIM7 TRGO - TIM5 TRGO <sup>(1)</sup> - TIM2 TRGO - TIM4 TRGO <sup>(1)</sup> - EXTI line9 - SW TRIG Additional trigger for STM32L4Rxxx/4Sxxx: - TIM1_TRGO - TIM15_TRGO - LPTIM1_OUT - LPTMI2_OUT |

<sup>1.</sup> Except on STM32L43xxx/L44xxx devices.

62/75 AN4809 Rev 5

AN4809 Peripheral migration

## 5.11 Comparator (COMP)

Both series embed two comparators that can be used for a variety of functions including:

- Wake up from the low-power mode triggered by an analog signal
- Analog signal conditioning
- Cycle-by-cycle current control loop when combined with a PWM output from a timer.

*Table 33* presents the differences between the COMP interface of STM32L0 Series and STM32L4 Series / STM32L4+ Series.

Table 33. COMP differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series

| СОМР     | STM32L0 Series                                                                                                                                                  | STM32L4 Series / STM32L4+ Series                                                                                               |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Туре     | <ul><li>COMP1 ultra-low-power</li><li>COMP2 Rail to rail</li></ul>                                                                                              | <ul><li>COMP1</li><li>COMP2 Rail to rail</li></ul>                                                                             |
| Inputs + | <ul><li>COMP1 &amp; COMP2</li><li>PA3/PB4/PA5(DAC2)/PB6/PB7</li><li>COMP1</li><li>PA1</li></ul>                                                                 | - PC5/PB2 (COMP1)<br>- PB4/PB6 (COMP2)                                                                                         |
| Inputs - | - COMP1: VREFINT PA0 DAC Channel1 (PA4) DAC Channel2 (PA5) - COMP2: ½ VREFINT ½ VREFINT ¾ VREFINT VREFINT VREFINT PA2 DAC Channel1 (PA4) DAC Channel2 (PA5) PB3 | - COMP1& COMP2:  1/4 VREFINT 1/2 VREFINT 3/4 VREFINT VREFINT VREFINT DAC Channel1 DAC Channel2 PB1/PC4 (COMP1) PB3/ PB7(COMP2) |
| Outputs  | - EXTI line - GPIOx - Timers input                                                                                                                              |                                                                                                                                |
|          | Window comparator                                                                                                                                               | Window comparator                                                                                                              |
|          | NA                                                                                                                                                              | Hysteresis                                                                                                                     |
| Features | NA                                                                                                                                                              | Output with Blanking Source     Programmable hysteresis                                                                        |
|          | COMP2 only:  - High speed/ full power  - Low speed / low-power                                                                                                  | Power/speed modes:  - High speed/ full power  - Medium speed/ medium power  - Low speed/ ultra-low-power                       |



AN4809 Rev 5 63/75

Firmware migration AN4809

## 6 Firmware migration

The STM32L0 Series and STM32L4 Series / STM32L4+ Series libraries have the same architecture and are CMSIS compliant, they use the same driver naming and the same APIs for all compatible peripherals.

The HAL libraries has been built in order to reduce the migration needs between products through the usage of high level functions usable by all products.

Only a few peripheral drivers need to be updated to migrate the application from one series to another.

As examples, the next sections focus on the most sensible features: FLASH, PWR and RCC settings/ activation.

#### 6.1 HAL FLASH

STM32L0 Series and STM32L4 Series / STM32L4+ Series are based on the different Flash memory technology with different controllers. Refer to *Section 5.6* for detailed description of these differences. The impacts on software concern the option bytes access, the data access and the protections settings:

- Different option byte structures
- PCROP settings
- Word length
- EEPROM for the STM32L0 Series only

*Table 34* gives the option byte structures in both series. On STM32L0 Series the PCROP protection is managed by setting a bit for each sector to protect, while on STM32L4 Series / STM32L4+ Series the user defines the start and end protection address into the dedicated PCROP address registers (FLASH\_PCROP1SR, FLASH\_PCROP1ER, FLASH\_PCROP2SR, FLASH\_PCROP2ER).

On STM32L0 Series, the SPRMOD bit sets the protection mode from WRP to PCROP while, on STM32L4 Series / STM32L4+ Series, the protection modes can be set separately.



AN4809 Firmware migration

Table 34. Option byte structure comparison

| Structure                     | STM32L0 Series                                                                                                                                           | STM32L4 Series /<br>STM32L4+ Series                                                                                                                                                                           |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FLASH_OBProgramInitTypeDef    | uint32_t OptionType uint32_t WRPState uint32_t WRPSector uint32_t WRPSector2 uint8_t RDPLevel uint8_t BORLevel uint8_t USERConfig uint8_t BOOTBit1Config | uint32_t OptionType uint32_t WRPArea uint32_t WRPStartOffset uint32_t WRPEndOffset uint32_t RDPLevel uint32_t USERType uint32_t USERConfig uint32_t PCROPConfig uint32_t PCROPStartAddr uint32_t PCROPEndAddr |
| FLASH_AdvOBProgramInitTypeDef | uint32_t OptionType uint8_t PCROPState uint32_t PCROPSector uint32_t PCROPSector2 uint8_t BootConfig                                                     | NA                                                                                                                                                                                                            |

#### **Generic API**

Both series share the same generic API. The only difference is the Flash memory word size: 32 bits in STM32L0 Series and 64 bits in STM32L4 Series / STM32L4+ Series (*Table 35*).

Table 35. FLASH generic API

| FLASH Generic API                | STM32L0 Series | STM32L4 Series /<br>STM32L4+ Series |
|----------------------------------|----------------|-------------------------------------|
| HAL_FLASH_Program                | Uint32_t data  | Uint64_t data                       |
| HAL_FLASH_Program_IT             | Uint32_t data  | Uint64_t data                       |
| HAL_FLASH_IRQHandler             |                |                                     |
| HAL_FLASH_EndOfOperationCallback | Same prototype |                                     |
| HAL_FLASH_OperationErrorCallback |                |                                     |
| HAL_FLASH_Unlock                 |                |                                     |
| HAL_FLASH_Lock                   |                |                                     |
| HAL_FLASH_OB_Unlock              |                |                                     |
| HAL_FLASH_OB_Lock                |                |                                     |
| HAL_FLASH_OB_Launch              |                |                                     |
| HAL_FLASH_GetError               |                |                                     |



AN4809 Rev 5 65/75

Firmware migration AN4809

#### **Extended API**

The extended HAL functions are dedicated to the option bytes programming and the EEPROM management.

Table 36. FLASH extended API

| FLASH Extended API                             | STM32L0<br>Series | STM32L4<br>Series /<br>STM32L4+<br>Series |
|------------------------------------------------|-------------------|-------------------------------------------|
| HAL_FLASHEx_Erase                              |                   |                                           |
| HAL_FLASHEx_Erase_IT                           | Samon             | rototypo                                  |
| HAL_FLASHEx_OBProgram                          | Same prototype    |                                           |
| HAL_FLASHEx_OBGetConfig                        |                   |                                           |
| HAL_FLASHEx_AdvOBProgram                       |                   | NA                                        |
| HAL_FLASHEx_AdvOBGetConfig                     | Used for<br>PCROP | All OB                                    |
| HAL_FLASHEx_OB_SelectPCROP                     | configuration     | programmed in HAL_FLASHEx                 |
| HAL_FLASHEx_OB_DeSelectPCROP                   | _OBProgram        |                                           |
| HAL_FLASHEx_DATAEEPROM_Unlock                  |                   |                                           |
| HAL_FLASHEx_DATAEEPROM_Lock                    |                   |                                           |
| HAL_FLASHEx_DATAEEPROM_Erase                   | EEPROM            | NA                                        |
| HAL_FLASHEx_DATAEEPROM_Program                 | configuration     | No EEPROM                                 |
| HAL_FLASHEx_DATAEEPROM_EnableFixedTimeProgram  |                   |                                           |
| HAL_FLASHEx_DATAEEPROM_DisableFixedTimeProgram |                   |                                           |

AN4809 Firmware migration

## 6.2 HAL PWR

The HAL\_PWR functions are used to configure the power management strategy: the low-power mode selection, the wakeup management and the power voltage monitoring. *Table 37* presents the main power API. It is dedicated to the special power management features available (mostly) in STM32L4 Series / STM32L4+ Series.

There are five low-power modes in STM32L0 Series (low-power run, sleep, low-power sleep, stop and standby) and nine in STM32L4 Series / STM32L4+ Series (low-power run, sleep, low-power sleep, Stop 0, Stop 1, Stop 2, standby with or without SRAM2 retention and shutdown).

#### **Generic API**

Table 37. HAL PWR

| Table 57. HAL_I WIX        |                                                                                       |                                     |  |
|----------------------------|---------------------------------------------------------------------------------------|-------------------------------------|--|
| Power management API       | STM32L0 Series                                                                        | STM32L4 Series /<br>STM32L4+ Series |  |
| HAL_PWR_DeInit             |                                                                                       | Same prototype                      |  |
| HAL_PWR_EnableBkUpAccess   |                                                                                       | Backup registers                    |  |
| HAL_PWR_DisableBkUpAccess  |                                                                                       | Same prototypes                     |  |
| HAL_PWR_ConfigPVD          |                                                                                       |                                     |  |
| HAL_PWR_EnablePVD          | Prograr                                                                               | mmable voltage detector             |  |
| HAL_PWR_DisablePVD         |                                                                                       | Same prototypes                     |  |
| HAL_PWR_PVDCallback        |                                                                                       |                                     |  |
| HAL_PWR_EnableWakeUpPin    | 0                                                                                     |                                     |  |
| HAL_PWR_DisableWakeUpPin   | Same prototypes                                                                       |                                     |  |
| HAL_PWR_EnterSLEEPMode     | Sleep and Low-power sleep modes (depending on regulator status)                       |                                     |  |
| HAL_PWR_EnterSTOPMode      | Stop mode  For legacy only. See HAL_PWREx_EnterSTOP1Mode and HAL_PWREx_EnterSTOP2Mode |                                     |  |
| HAL_PWR_EnterSTANDBYMode   | Standby mode                                                                          |                                     |  |
| HAL_PWR_EnableSleepOnExit  | Same prototypes                                                                       |                                     |  |
| HAL_PWR_DisableSleepOnExit |                                                                                       |                                     |  |
| HAL_PWR_EnableSEVOnPend    |                                                                                       |                                     |  |
| HAL_PWR_DisableSEVOnPend   |                                                                                       |                                     |  |

The power extension API is for management of the new power features available in STM32L4 Series / STM32L4+ Series. The STM32L0 API extension concerns the low-power and ultra-low-power (ULP) modes.



AN4809 Rev 5 67/75

Firmware migration AN4809

## **Extended API**

Table 38. HAL\_PWREx

| Extended Power API                     | STM32L0 Series        | STM32L4 Series /<br>STM32L4+ Series |  |
|----------------------------------------|-----------------------|-------------------------------------|--|
| HAL_PWREx_GetVoltageRange              |                       | Main regulator range                |  |
| HAL_PWREx_ControlVoltageScaling        |                       | (1 or 2)                            |  |
| HAL_PWREx_EnableBatteryCharging        |                       | Battery charging                    |  |
| HAL_PWREx_DisableBatteryCharging       |                       | Battery charging                    |  |
| HAL_PWREx_EnableVddUSB                 |                       | LISP cumply                         |  |
| HAL_PWREx_DisableVddUSB                | USB supply            |                                     |  |
| HAL_PWREx_EnableVddIO2                 | 100                   |                                     |  |
| HAL_PWREx_DisableVddIO2                | IO2 supply            |                                     |  |
| HAL_PWREx_EnableInternalWakeUpLine     |                       | Internal Wakeup line                |  |
| HAL_PWREx_DisableInternalWakeUpLine    |                       | Internal Wakeup line                |  |
| HAL_PWREx_EnableGPIOPullUp             |                       |                                     |  |
| HAL_PWREx_DisableGPIOPullUp            |                       |                                     |  |
| HAL_PWREx_EnableGPIOPullDown           |                       | Manage GPIO state in                |  |
| HAL_PWREx_DisableGPIOPullDown          |                       | Standby and Shutdown modes          |  |
| HAL_PWREx_EnablePullUpPullDownConfig   |                       |                                     |  |
| HAL_PWREx_DisablePullUpPullDownConfig  |                       |                                     |  |
| HAL_PWREx_EnableSRAM2ContentRetention  | NA                    | Retention configuration             |  |
| HAL_PWREx_DisableSRAM2ContentRetention |                       | in Standby mode                     |  |
| HAL_PWREx_EnablePVM1                   |                       | VDDUSB versus 1.2V                  |  |
| HAL_PWREx_DisablePVM1                  | VDDUSB vers           |                                     |  |
| HAL_PWREx_EnablePVM2                   |                       | VDDUSB versus 0.9V                  |  |
| HAL_PWREx_DisablePVM2                  |                       | VDDOSB Versus 0.9V                  |  |
| HAL_PWREx_EnablePVM3                   |                       | VDDUSB vorsus 1.62V                 |  |
| HAL_PWREx_DisablePVM3                  | HAL_PWREx_DisablePVM3 |                                     |  |
| HAL_PWREx_EnablePVM4                   |                       | VDDA voreus 2.2V                    |  |
| HAL_PWREx_DisablePVM4                  | VDDA versus 2.2V      |                                     |  |
| HAL_PWREx_ConfigPVM                    |                       |                                     |  |
| HAL_PWREx_PVM1Callback                 |                       |                                     |  |
| HAL_PWREx_PVM2Callback                 |                       | DVM management                      |  |
| HAL_PWREx_PVM3Callback                 |                       | PVM management                      |  |
| HAL_PWREx_PVM4Callback                 |                       |                                     |  |
| HAL_PWREx_PVD_PVM_IRQHandler           |                       |                                     |  |
| HAL_PWREx_EnterSTOP0Mode               | Stop 0 mode           |                                     |  |

AN4809 Firmware migration

Table 38. HAL\_PWREx (continued)

| Extended Power API               | STM32L0 Series STM32L4 Ser<br>STM32L4+ Se |               |
|----------------------------------|-------------------------------------------|---------------|
| HAL_PWREx_EnterSTOP1Mode         | Stop 1 mode                               |               |
| HAL_PWREx_EnterSTOP2Mode         | NA                                        | Stop 2 mode   |
| HAL_PWREx_EnterSHUTDOWNMode      |                                           | Shutdown mode |
| HAL_PWREx_EnableLowPowerRunMode  | Low-power run mode Entry/Exit             |               |
| HAL_PWREx_DisableLowPowerRunMode |                                           |               |
| HAL_PWREx_EnableUltraLowPower    | ULP = Low-power                           |               |
| HAL_PWREx_DisableUltraLowPower   | mode with VREFINT<br>OFF                  | NA            |
| HAL_PWREx_EnableFastWakeUp       | - Wakeup config. in ULP                   |               |
| HAL_PWREx_DisableFastWakeUp      | wakeup coiling. III OLF                   |               |

Firmware migration AN4809

#### 6.3 HAL RCC

There are few differences in HAL\_RCC between STM32L0 Series and STM32L4 Series / STM32L4+ Series. The PLL has specific configurations (see *Table 39*) and there is a wider range of peripherals supported by RCC\_PeriphCLKInitTypeDef in STM32L4 Series / STM32L4+ Series.

Table 39. PLL configuration

| STM32L0 Series     | STM32L4 Series / STM32L4+ Series |                                                   |
|--------------------|----------------------------------|---------------------------------------------------|
| Main PLL           | Main PLL                         | SAIx PLL                                          |
| uint32_t PLLState  | uint32_t PLLState                | uint32_t PLLSAlxN                                 |
| uint32_t PLLSource | uint32_t PLLSource               | uint32_t PLLSAlxP                                 |
| uint32_t PLLMUL    | uint32_t PLLM                    | uint32_t PLLSAlxQ                                 |
| uint32_t PLLDIV    | uint32_t PLLN                    | uint32_t PLLSAlxR                                 |
| -                  | uint32_t PLLP                    | uint32_t PLLSAlxClockOut                          |
| -                  | uint32_t PLLQ                    | uint32_t PLLSAIxM<br>(only for STM32L4Rxxx/4Sxxx) |
| -                  | uint32_t PLLR                    | -                                                 |

#### **Generic API**

All the following functions have the same prototype in both series.

- HAL\_RCC\_Delnit
- HAL\_RCC\_OscConfig
- HAL\_RCC\_ClockConfig
- HAL\_RCC\_MCOConfig
- HAL\_RCC\_EnableCSS
- HAL\_RCC\_GetSysClockFreq
- HAL\_RCC\_GetHCLKFreq
- HAL\_RCC\_GetPCLK1Freq
- HAL RCC GetPCLK2Freq
- HAL\_RCC\_GetOscConfig
- HAL RCC GetClockConfig
- HAL\_RCC\_NMI\_IRQHandler
- HAL\_RCC\_CSSCallback

AN4809 Firmware migration

#### **Extended API**

The main differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series are on specific blocks: the CRS for STM32L0 Series devices and the SAI PLLs in STM32L4 Series / STM32L4+ Series devices. *Table 40* compares the HAL\_RCCEx API for both series.

Table 40. RCC extended peripheral control functions

| RCC Extension API                            | STM32L0 Series                   | STM32L4<br>Series /<br>STM32L4+<br>Series |
|----------------------------------------------|----------------------------------|-------------------------------------------|
| HAL_RCC_DeInit                               | Reset Default RCC settings       |                                           |
| HAL_RCCEx_PeriphCLKConfig                    | Manage peripherals clocks        |                                           |
| HAL_RCCEx_GetPeriphCLKConfig                 |                                  |                                           |
| HAL_RCCEx_GetPeriphCLKFreq                   |                                  |                                           |
| HAL_RCCEx_EnableLSECSS                       |                                  |                                           |
| HAL_RCCEx_DisableLSECSS                      | Manage LSE clock Security system |                                           |
| HAL_RCCEx_EnableLSECSS_IT                    |                                  |                                           |
| HAL_RCCEx_LSECSS_IRQHandler                  |                                  |                                           |
| HAL_RCCEx_LSECSS_Callback                    |                                  |                                           |
| HAL_RCCEx_CRSConfig                          |                                  |                                           |
| HAL_RCCEx_CRSSoftwareSynchronizationGenerate | Manage Clock NA Recovery System  |                                           |
| HAL_RCCEx_CRSGetSynchronizationInfo          |                                  |                                           |
| HAL_RCCEx_CRSWaitSynchronization             |                                  |                                           |
| HAL_RCCEx_EnableHSI48_VREFINT                | - VREFINT for HSI48 NA           |                                           |
| HAL_RCCEx_DisableHSI48_VREFINT               |                                  |                                           |

AN4809 Rev 5 71/75

Firmware migration AN4809

Table 40. RCC extended peripheral control functions (continued)

| RCC Extension API               | STM32L0 Series | STM32L4<br>Series /<br>STM32L4+<br>Series                           |
|---------------------------------|----------------|---------------------------------------------------------------------|
| HAL_RCCEx_EnableLSCO            |                | Low Speed clock source to                                           |
| HAL_RCCEx_DisableLSCO           |                | output on<br>LSCO pin<br>(PA2)                                      |
| HAL_RCCEx_EnableMSIPLLMode      |                | PLL mode for MSI                                                    |
| HAL_RCCEx_DisableMSIPLLMode     |                | (calibration<br>LSE)                                                |
| HAL_RCCEx_EnablePLLSAI1         |                | Enable/Disable                                                      |
| HAL_RCCEx_DisablePLLSAI1        |                |                                                                     |
| HAL_RCCEx_EnablePLLSAI2         | IVA            | and SAI2<br>interfaces                                              |
| HAL_RCCEx_DisablePLLSAI2        |                | interfaces                                                          |
| HAL_RCCEx_WakeUpStopCLKConfig   |                | Stop mode<br>wakeup or<br>CSS backup<br>clock<br>(HSI/MSI)          |
| HAL_RCCEx_StandbyMSIRangeConfig |                | Configure the<br>MSI range after<br>Standby mode<br>(default 4 MHz) |

AN4809 Revision history

## 7 Revision history

Table 41. Document revision history

| Date        | Revision | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 08-Jul-2016 | 1        | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14-Feb-2017 | 2        | Updated the whole document with reference to:  STM32L49xxx/L4Axxx devices  STM32L47xxx/L48xxx devices  STM32L45xxx/L46xxx devices  STM32L45xxx/L46xxx devices  STM32L43xxx/L44xxx devices  Updated STM32L4 Series and STM32L0 Series reference manual list in cover.  Removed STM32L4 Series product category overview table.  Added Table 4: STM32L4 Series / STM32L4+ Series feature levels.  Updated Table 5: STM32L4 Series / STM32L4+ Series memory availability.  Updated Section 2.1: Packages availability:  Added Table 6: Packages available on STM32L4 Series and STM32L4+ Series.  Updated Table 7: Packages available on STM32L0 Series.  Added Section : SMPS packages.  Updated Table 17: Boot modes for STM32L41xxx/L42xxx, STM32L43xxx/L44xxx, STM32L45xxx/L46xxx, STM32L43xxx/L44xxx and STM32L44xxx devices.  Added I2C4, CAN2 in Table 18: Boot serial interfaces.  Updated Table 20: STM32L4 Series / STM32L4+ Series low-power modes summary.  Added DCMI in Table 21: Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series. |
| 31-Aug-2017 | 3        | Updated the whole document to add STM32L4+ Series information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



AN4809 Rev 5 73/75

Revision history AN4809

Table 41. Document revision history

| Date        | Revision | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22-Nov-2017 | 4        | Added:  - Table 13: Pinout differences on BGA64 package  - Table 14: Pinout differences on UFBGA100 package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 20-Sep-2018 | 5        | Added:  Information related to STM32L41xxx/42xxx to the whole document  Table 8: Pinout differences on LQFP32 package  Updated:  Cover page  STM32L0 Cat. 2, 3, 5 and STM32L47xxx/L48xxx devices on page 19  Note: on page 39  Table 5: STM32L4 Series / STM32L4+ Series memory availability  Table 6: Packages available on STM32L4 Series and STM32L4+ Series  Table 17: Boot modes for STM32L41xxx/L42xxx, STM32L43xxx/L44xxx, STM32L45xxx/L46xxx, STM32L49xxx/L4Axxx and STM32L4Rxxx/45xxx devices  Table 18: Boot serial interfaces  Footnote 3. on Table 20: STM32L4 Series / STM32L4+ Series low-power modes summary  Table 21: Peripherals comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series  Table 24: RCC comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series  Table 26: PWR comparison between STM32L0 Series and STM32L4 Series / STM32L4+ Series  Table 27: FLASH differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series  Table 30: USB peripheral comparison  Table 31: ADC differences between STM32L0 Series and STM32L4 Series / STM32L4+ Series |

#### IMPORTANT NOTICE - PLEASE READ CAREFULLY

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2018 STMicroelectronics - All rights reserved



AN4809 Rev 5 75/75